2011-07-14 10:45:20 -04:00
< ? php
require_once 'propel/util/BasePeer.php' ;
// The object class -- needed for instanceof checks in this class.
// actual class may be a subclass -- as returned by AppNotesPeer::getOMClass()
2013-01-28 16:49:00 -04:00
include_once 'classes/model/AppNotes.php' ;
2011-07-14 10:45:20 -04:00
/**
* Base static class for performing query and update operations on the 'APP_NOTES' table .
*
*
*
* @ package workflow . classes . model . om
*/
2012-10-04 17:54:44 -04:00
abstract class BaseAppNotesPeer
{
/** the default database name for this class */
const DATABASE_NAME = 'workflow' ;
/** the table name for this class */
const TABLE_NAME = 'APP_NOTES' ;
/** A class that can be returned by this peer. */
const CLASS_DEFAULT = 'classes.model.AppNotes' ;
/** The total number of columns. */
2020-06-04 10:38:48 -04:00
const NUM_COLUMNS = 11 ;
2012-10-04 17:54:44 -04:00
/** The number of lazy-loaded columns. */
const NUM_LAZY_LOAD_COLUMNS = 0 ;
2020-06-04 10:38:48 -04:00
/** the column name for the NOTE_ID field */
const NOTE_ID = 'APP_NOTES.NOTE_ID' ;
2012-10-04 17:54:44 -04:00
/** the column name for the APP_UID field */
const APP_UID = 'APP_NOTES.APP_UID' ;
/** the column name for the USR_UID field */
const USR_UID = 'APP_NOTES.USR_UID' ;
/** the column name for the NOTE_DATE field */
const NOTE_DATE = 'APP_NOTES.NOTE_DATE' ;
/** the column name for the NOTE_CONTENT field */
const NOTE_CONTENT = 'APP_NOTES.NOTE_CONTENT' ;
/** the column name for the NOTE_TYPE field */
const NOTE_TYPE = 'APP_NOTES.NOTE_TYPE' ;
/** the column name for the NOTE_AVAILABILITY field */
const NOTE_AVAILABILITY = 'APP_NOTES.NOTE_AVAILABILITY' ;
/** the column name for the NOTE_ORIGIN_OBJ field */
const NOTE_ORIGIN_OBJ = 'APP_NOTES.NOTE_ORIGIN_OBJ' ;
/** the column name for the NOTE_AFFECTED_OBJ1 field */
const NOTE_AFFECTED_OBJ1 = 'APP_NOTES.NOTE_AFFECTED_OBJ1' ;
/** the column name for the NOTE_AFFECTED_OBJ2 field */
const NOTE_AFFECTED_OBJ2 = 'APP_NOTES.NOTE_AFFECTED_OBJ2' ;
/** the column name for the NOTE_RECIPIENTS field */
const NOTE_RECIPIENTS = 'APP_NOTES.NOTE_RECIPIENTS' ;
/** The PHP to DB Name Mapping */
private static $phpNameMap = null ;
/**
* holds an array of fieldnames
*
* first dimension keys are the type constants
* e . g . self :: $fieldNames [ self :: TYPE_PHPNAME ][ 0 ] = 'Id'
*/
private static $fieldNames = array (
2020-06-04 10:38:48 -04:00
BasePeer :: TYPE_PHPNAME => array ( 'NoteId' , 'AppUid' , 'UsrUid' , 'NoteDate' , 'NoteContent' , 'NoteType' , 'NoteAvailability' , 'NoteOriginObj' , 'NoteAffectedObj1' , 'NoteAffectedObj2' , 'NoteRecipients' , ),
BasePeer :: TYPE_COLNAME => array ( AppNotesPeer :: NOTE_ID , AppNotesPeer :: APP_UID , AppNotesPeer :: USR_UID , AppNotesPeer :: NOTE_DATE , AppNotesPeer :: NOTE_CONTENT , AppNotesPeer :: NOTE_TYPE , AppNotesPeer :: NOTE_AVAILABILITY , AppNotesPeer :: NOTE_ORIGIN_OBJ , AppNotesPeer :: NOTE_AFFECTED_OBJ1 , AppNotesPeer :: NOTE_AFFECTED_OBJ2 , AppNotesPeer :: NOTE_RECIPIENTS , ),
BasePeer :: TYPE_FIELDNAME => array ( 'NOTE_ID' , 'APP_UID' , 'USR_UID' , 'NOTE_DATE' , 'NOTE_CONTENT' , 'NOTE_TYPE' , 'NOTE_AVAILABILITY' , 'NOTE_ORIGIN_OBJ' , 'NOTE_AFFECTED_OBJ1' , 'NOTE_AFFECTED_OBJ2' , 'NOTE_RECIPIENTS' , ),
BasePeer :: TYPE_NUM => array ( 0 , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , )
2012-10-04 17:54:44 -04:00
);
/**
* holds an array of keys for quick access to the fieldnames array
*
* first dimension keys are the type constants
* e . g . self :: $fieldNames [ BasePeer :: TYPE_PHPNAME ][ 'Id' ] = 0
*/
private static $fieldKeys = array (
2020-06-04 10:38:48 -04:00
BasePeer :: TYPE_PHPNAME => array ( 'NoteId' => 0 , 'AppUid' => 1 , 'UsrUid' => 2 , 'NoteDate' => 3 , 'NoteContent' => 4 , 'NoteType' => 5 , 'NoteAvailability' => 6 , 'NoteOriginObj' => 7 , 'NoteAffectedObj1' => 8 , 'NoteAffectedObj2' => 9 , 'NoteRecipients' => 10 , ),
BasePeer :: TYPE_COLNAME => array ( AppNotesPeer :: NOTE_ID => 0 , AppNotesPeer :: APP_UID => 1 , AppNotesPeer :: USR_UID => 2 , AppNotesPeer :: NOTE_DATE => 3 , AppNotesPeer :: NOTE_CONTENT => 4 , AppNotesPeer :: NOTE_TYPE => 5 , AppNotesPeer :: NOTE_AVAILABILITY => 6 , AppNotesPeer :: NOTE_ORIGIN_OBJ => 7 , AppNotesPeer :: NOTE_AFFECTED_OBJ1 => 8 , AppNotesPeer :: NOTE_AFFECTED_OBJ2 => 9 , AppNotesPeer :: NOTE_RECIPIENTS => 10 , ),
BasePeer :: TYPE_FIELDNAME => array ( 'NOTE_ID' => 0 , 'APP_UID' => 1 , 'USR_UID' => 2 , 'NOTE_DATE' => 3 , 'NOTE_CONTENT' => 4 , 'NOTE_TYPE' => 5 , 'NOTE_AVAILABILITY' => 6 , 'NOTE_ORIGIN_OBJ' => 7 , 'NOTE_AFFECTED_OBJ1' => 8 , 'NOTE_AFFECTED_OBJ2' => 9 , 'NOTE_RECIPIENTS' => 10 , ),
BasePeer :: TYPE_NUM => array ( 0 , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , )
2012-10-04 17:54:44 -04:00
);
/**
* @ return MapBuilder the map builder for this peer
* @ throws PropelException Any exceptions caught during processing will be
* rethrown wrapped into a PropelException .
*/
public static function getMapBuilder ()
{
include_once 'classes/model/map/AppNotesMapBuilder.php' ;
return BasePeer :: getMapBuilder ( 'classes.model.map.AppNotesMapBuilder' );
}
/**
* Gets a map ( hash ) of PHP names to DB column names .
*
* @ return array The PHP to DB name map for this peer
* @ throws PropelException Any exceptions caught during processing will be
* rethrown wrapped into a PropelException .
* @ deprecated Use the getFieldNames () and translateFieldName () methods instead of this .
*/
public static function getPhpNameMap ()
{
if ( self :: $phpNameMap === null ) {
$map = AppNotesPeer :: getTableMap ();
$columns = $map -> getColumns ();
$nameMap = array ();
foreach ( $columns as $column ) {
$nameMap [ $column -> getPhpName ()] = $column -> getColumnName ();
}
self :: $phpNameMap = $nameMap ;
}
return self :: $phpNameMap ;
}
/**
* Translates a fieldname to another type
*
* @ param string $name field name
* @ param string $fromType One of the class type constants TYPE_PHPNAME ,
* TYPE_COLNAME , TYPE_FIELDNAME , TYPE_NUM
* @ param string $toType One of the class type constants
* @ return string translated name of the field .
*/
static public function translateFieldName ( $name , $fromType , $toType )
{
$toNames = self :: getFieldNames ( $toType );
$key = isset ( self :: $fieldKeys [ $fromType ][ $name ]) ? self :: $fieldKeys [ $fromType ][ $name ] : null ;
if ( $key === null ) {
throw new PropelException ( " ' $name ' could not be found in the field names of type ' $fromType '. These are: " . print_r ( self :: $fieldKeys [ $fromType ], true ));
}
return $toNames [ $key ];
}
/**
* Returns an array of of field names .
*
* @ param string $type The type of fieldnames to return :
* One of the class type constants TYPE_PHPNAME ,
* TYPE_COLNAME , TYPE_FIELDNAME , TYPE_NUM
* @ return array A list of field names
*/
static public function getFieldNames ( $type = BasePeer :: TYPE_PHPNAME )
{
if ( ! array_key_exists ( $type , self :: $fieldNames )) {
throw new PropelException ( 'Method getFieldNames() expects the parameter $type to be one of the class constants TYPE_PHPNAME, TYPE_COLNAME, TYPE_FIELDNAME, TYPE_NUM. ' . $type . ' was given.' );
}
return self :: $fieldNames [ $type ];
}
/**
* Convenience method which changes table . column to alias . column .
*
* Using this method you can maintain SQL abstraction while using column aliases .
* < code >
* $c -> addAlias ( " alias1 " , TablePeer :: TABLE_NAME );
* $c -> addJoin ( TablePeer :: alias ( " alias1 " , TablePeer :: PRIMARY_KEY_COLUMN ), TablePeer :: PRIMARY_KEY_COLUMN );
* </ code >
* @ param string $alias The alias for the current table .
* @ param string $column The column name for current table . ( i . e . AppNotesPeer :: COLUMN_NAME ) .
* @ return string
*/
public static function alias ( $alias , $column )
{
return str_replace ( AppNotesPeer :: TABLE_NAME . '.' , $alias . '.' , $column );
}
/**
* Add all the columns needed to create a new object .
*
* Note : any columns that were marked with lazyLoad = " true " in the
* XML schema will not be added to the select list and only loaded
* on demand .
*
* @ param criteria object containing the columns to add .
* @ throws PropelException Any exceptions caught during processing will be
* rethrown wrapped into a PropelException .
*/
public static function addSelectColumns ( Criteria $criteria )
{
2020-06-04 10:38:48 -04:00
$criteria -> addSelectColumn ( AppNotesPeer :: NOTE_ID );
2012-10-04 17:54:44 -04:00
$criteria -> addSelectColumn ( AppNotesPeer :: APP_UID );
$criteria -> addSelectColumn ( AppNotesPeer :: USR_UID );
$criteria -> addSelectColumn ( AppNotesPeer :: NOTE_DATE );
$criteria -> addSelectColumn ( AppNotesPeer :: NOTE_CONTENT );
$criteria -> addSelectColumn ( AppNotesPeer :: NOTE_TYPE );
$criteria -> addSelectColumn ( AppNotesPeer :: NOTE_AVAILABILITY );
$criteria -> addSelectColumn ( AppNotesPeer :: NOTE_ORIGIN_OBJ );
$criteria -> addSelectColumn ( AppNotesPeer :: NOTE_AFFECTED_OBJ1 );
$criteria -> addSelectColumn ( AppNotesPeer :: NOTE_AFFECTED_OBJ2 );
$criteria -> addSelectColumn ( AppNotesPeer :: NOTE_RECIPIENTS );
}
const COUNT = 'COUNT(*)' ;
const COUNT_DISTINCT = 'COUNT(DISTINCT *)' ;
/**
* Returns the number of rows matching criteria .
*
* @ param Criteria $criteria
* @ param boolean $distinct Whether to select only distinct columns ( You can also set DISTINCT modifier in Criteria ) .
* @ param Connection $con
* @ return int Number of matching rows .
*/
public static function doCount ( Criteria $criteria , $distinct = false , $con = null )
{
// we're going to modify criteria, so copy it first
$criteria = clone $criteria ;
// clear out anything that might confuse the ORDER BY clause
$criteria -> clearSelectColumns () -> clearOrderByColumns ();
if ( $distinct || in_array ( Criteria :: DISTINCT , $criteria -> getSelectModifiers ())) {
$criteria -> addSelectColumn ( AppNotesPeer :: COUNT_DISTINCT );
} else {
$criteria -> addSelectColumn ( AppNotesPeer :: COUNT );
}
// just in case we're grouping: add those columns to the select statement
foreach ( $criteria -> getGroupByColumns () as $column ) {
$criteria -> addSelectColumn ( $column );
}
$rs = AppNotesPeer :: doSelectRS ( $criteria , $con );
if ( $rs -> next ()) {
return $rs -> getInt ( 1 );
} else {
// no rows returned; we infer that means 0 matches.
return 0 ;
}
}
/**
* Method to select one object from the DB .
*
* @ param Criteria $criteria object used to create the SELECT statement .
* @ param Connection $con
* @ return AppNotes
* @ throws PropelException Any exceptions caught during processing will be
* rethrown wrapped into a PropelException .
*/
public static function doSelectOne ( Criteria $criteria , $con = null )
{
$critcopy = clone $criteria ;
$critcopy -> setLimit ( 1 );
$objects = AppNotesPeer :: doSelect ( $critcopy , $con );
if ( $objects ) {
return $objects [ 0 ];
}
return null ;
}
/**
* Method to do selects .
*
* @ param Criteria $criteria The Criteria object used to build the SELECT statement .
* @ param Connection $con
* @ return array Array of selected Objects
* @ throws PropelException Any exceptions caught during processing will be
* rethrown wrapped into a PropelException .
*/
public static function doSelect ( Criteria $criteria , $con = null )
{
return AppNotesPeer :: populateObjects ( AppNotesPeer :: doSelectRS ( $criteria , $con ));
}
/**
* Prepares the Criteria object and uses the parent doSelect ()
* method to get a ResultSet .
*
* Use this method directly if you want to just get the resultset
* ( instead of an array of objects ) .
*
* @ param Criteria $criteria The Criteria object used to build the SELECT statement .
* @ param Connection $con the connection to use
* @ throws PropelException Any exceptions caught during processing will be
* rethrown wrapped into a PropelException .
* @ return ResultSet The resultset object with numerically - indexed fields .
* @ see BasePeer :: doSelect ()
*/
public static function doSelectRS ( Criteria $criteria , $con = null )
{
if ( $con === null ) {
$con = Propel :: getConnection ( self :: DATABASE_NAME );
}
if ( ! $criteria -> getSelectColumns ()) {
$criteria = clone $criteria ;
AppNotesPeer :: addSelectColumns ( $criteria );
}
// Set the correct dbName
$criteria -> setDbName ( self :: DATABASE_NAME );
// BasePeer returns a Creole ResultSet, set to return
// rows indexed numerically.
return BasePeer :: doSelect ( $criteria , $con );
}
/**
* The returned array will contain objects of the default type or
* objects that inherit from the default .
*
* @ throws PropelException Any exceptions caught during processing will be
* rethrown wrapped into a PropelException .
*/
public static function populateObjects ( ResultSet $rs )
{
$results = array ();
// set the class once to avoid overhead in the loop
$cls = AppNotesPeer :: getOMClass ();
$cls = Propel :: import ( $cls );
// populate the object(s)
while ( $rs -> next ()) {
$obj = new $cls ();
$obj -> hydrate ( $rs );
$results [] = $obj ;
}
return $results ;
}
/**
* Returns the TableMap related to this peer .
* This method is not needed for general use but a specific application could have a need .
* @ return TableMap
* @ throws PropelException Any exceptions caught during processing will be
* rethrown wrapped into a PropelException .
*/
public static function getTableMap ()
{
return Propel :: getDatabaseMap ( self :: DATABASE_NAME ) -> getTable ( self :: TABLE_NAME );
}
/**
* The class that the Peer will make instances of .
*
* This uses a dot - path notation which is tranalted into a path
* relative to a location on the PHP include_path .
* ( e . g . path . to . MyClass -> 'path/to/MyClass.php' )
*
* @ return string path . to . ClassName
*/
public static function getOMClass ()
{
return AppNotesPeer :: CLASS_DEFAULT ;
}
/**
* Method perform an INSERT on the database , given a AppNotes or Criteria object .
*
* @ param mixed $values Criteria or AppNotes object containing data that is used to create the INSERT statement .
* @ param Connection $con the connection to use
* @ return mixed The new primary key .
* @ throws PropelException Any exceptions caught during processing will be
* rethrown wrapped into a PropelException .
*/
public static function doInsert ( $values , $con = null )
{
if ( $con === null ) {
$con = Propel :: getConnection ( self :: DATABASE_NAME );
}
if ( $values instanceof Criteria ) {
$criteria = clone $values ; // rename for clarity
} else {
$criteria = $values -> buildCriteria (); // build Criteria from AppNotes object
}
// Set the correct dbName
$criteria -> setDbName ( self :: DATABASE_NAME );
try {
// use transaction because $criteria could contain info
// for more than one table (I guess, conceivably)
$con -> begin ();
$pk = BasePeer :: doInsert ( $criteria , $con );
$con -> commit ();
} catch ( PropelException $e ) {
$con -> rollback ();
throw $e ;
}
return $pk ;
}
/**
* Method perform an UPDATE on the database , given a AppNotes or Criteria object .
*
* @ param mixed $values Criteria or AppNotes object containing data create the UPDATE statement .
* @ param Connection $con The connection to use ( specify Connection exert more control over transactions ) .
* @ return int The number of affected rows ( if supported by underlying database driver ) .
* @ throws PropelException Any exceptions caught during processing will be
* rethrown wrapped into a PropelException .
*/
public static function doUpdate ( $values , $con = null )
{
if ( $con === null ) {
$con = Propel :: getConnection ( self :: DATABASE_NAME );
}
$selectCriteria = new Criteria ( self :: DATABASE_NAME );
if ( $values instanceof Criteria ) {
$criteria = clone $values ; // rename for clarity
} else {
$criteria = $values -> buildCriteria (); // gets full criteria
$selectCriteria = $values -> buildPkeyCriteria (); // gets criteria w/ primary key(s)
}
// set the correct dbName
$criteria -> setDbName ( self :: DATABASE_NAME );
return BasePeer :: doUpdate ( $selectCriteria , $criteria , $con );
}
/**
* Method to DELETE all rows from the APP_NOTES table .
*
* @ return int The number of affected rows ( if supported by underlying database driver ) .
*/
public static function doDeleteAll ( $con = null )
{
if ( $con === null ) {
$con = Propel :: getConnection ( self :: DATABASE_NAME );
}
$affectedRows = 0 ; // initialize var to track total num of affected rows
try {
// use transaction because $criteria could contain info
// for more than one table or we could emulating ON DELETE CASCADE, etc.
$con -> begin ();
$affectedRows += BasePeer :: doDeleteAll ( AppNotesPeer :: TABLE_NAME , $con );
$con -> commit ();
return $affectedRows ;
} catch ( PropelException $e ) {
$con -> rollback ();
throw $e ;
}
}
/**
* Method perform a DELETE on the database , given a AppNotes or Criteria object OR a primary key value .
*
* @ param mixed $values Criteria or AppNotes object or primary key or array of primary keys
* which is used to create the DELETE statement
* @ param Connection $con the connection to use
* @ return int The number of affected rows ( if supported by underlying database driver ) .
* This includes CASCADE - related rows
* if supported by native driver or if emulated using Propel .
* @ throws PropelException Any exceptions caught during processing will be
* rethrown wrapped into a PropelException .
*/
public static function doDelete ( $values , $con = null )
{
if ( $con === null ) {
$con = Propel :: getConnection ( AppNotesPeer :: DATABASE_NAME );
}
if ( $values instanceof Criteria ) {
$criteria = clone $values ; // rename for clarity
} elseif ( $values instanceof AppNotes ) {
$criteria = $values -> buildCriteria ();
} else {
// it must be the primary key
$criteria = new Criteria ( self :: DATABASE_NAME );
// primary key is composite; we therefore, expect
// the primary key passed to be an array of pkey
// values
if ( count ( $values ) == count ( $values , COUNT_RECURSIVE )) {
// array is not multi-dimensional
$values = array ( $values );
}
$vals = array ();
foreach ( $values as $value ) {
}
}
// Set the correct dbName
$criteria -> setDbName ( self :: DATABASE_NAME );
$affectedRows = 0 ; // initialize var to track total num of affected rows
try {
// use transaction because $criteria could contain info
// for more than one table or we could emulating ON DELETE CASCADE, etc.
$con -> begin ();
$affectedRows += BasePeer :: doDelete ( $criteria , $con );
$con -> commit ();
return $affectedRows ;
} catch ( PropelException $e ) {
$con -> rollback ();
throw $e ;
}
}
/**
* Validates all modified columns of given AppNotes object .
* If parameter $columns is either a single column name or an array of column names
* than only those columns are validated .
*
* NOTICE : This does not apply to primary or foreign keys for now .
*
* @ param AppNotes $obj The object to validate .
* @ param mixed $cols Column name or array of column names .
*
* @ return mixed TRUE if all columns are valid or the error message of the first invalid column .
*/
public static function doValidate ( AppNotes $obj , $cols = null )
{
$columns = array ();
if ( $cols ) {
$dbMap = Propel :: getDatabaseMap ( AppNotesPeer :: DATABASE_NAME );
$tableMap = $dbMap -> getTable ( AppNotesPeer :: TABLE_NAME );
if ( ! is_array ( $cols )) {
$cols = array ( $cols );
}
foreach ( $cols as $colName ) {
if ( $tableMap -> containsColumn ( $colName )) {
$get = 'get' . $tableMap -> getColumn ( $colName ) -> getPhpName ();
$columns [ $colName ] = $obj -> $get ();
}
}
} else {
}
return BasePeer :: doValidate ( AppNotesPeer :: DATABASE_NAME , AppNotesPeer :: TABLE_NAME , $columns );
}
}
2011-07-14 10:45:20 -04:00
// static code to register the map builder for this Peer with the main Propel class
if ( Propel :: isInit ()) {
2012-10-04 17:54:44 -04:00
// the MapBuilder classes register themselves with Propel during initialization
// so we need to load them here.
try {
BaseAppNotesPeer :: getMapBuilder ();
} catch ( Exception $e ) {
Propel :: log ( 'Could not initialize Peer: ' . $e -> getMessage (), Propel :: LOG_ERR );
}
2011-07-14 10:45:20 -04:00
} else {
2012-10-04 17:54:44 -04:00
// even if Propel is not yet initialized, the map builder class can be registered
// now and then it will be loaded when Propel initializes.
require_once 'classes/model/map/AppNotesMapBuilder.php' ;
Propel :: registerMapBuilder ( 'classes.model.map.AppNotesMapBuilder' );
2011-07-14 10:45:20 -04:00
}
2012-10-04 17:54:44 -04:00