2010-12-02 23:34:41 +00: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 ShadowTablePeer::getOMClass()
include_once 'classes/model/ShadowTable.php' ;
/**
* Base static class for performing query and update operations on the 'SHADOW_TABLE' table .
*
*
*
2011-01-29 14:21:21 +00:00
* @ package workflow . classes . model . om
2010-12-02 23:34:41 +00:00
*/
2012-10-04 17:54:44 -04:00
abstract class BaseShadowTablePeer
{
/** the default database name for this class */
const DATABASE_NAME = 'workflow' ;
/** the table name for this class */
const TABLE_NAME = 'SHADOW_TABLE' ;
/** A class that can be returned by this peer. */
const CLASS_DEFAULT = 'classes.model.ShadowTable' ;
/** The total number of columns. */
const NUM_COLUMNS = 7 ;
/** The number of lazy-loaded columns. */
const NUM_LAZY_LOAD_COLUMNS = 0 ;
/** the column name for the SHD_UID field */
const SHD_UID = 'SHADOW_TABLE.SHD_UID' ;
/** the column name for the ADD_TAB_UID field */
const ADD_TAB_UID = 'SHADOW_TABLE.ADD_TAB_UID' ;
/** the column name for the SHD_ACTION field */
const SHD_ACTION = 'SHADOW_TABLE.SHD_ACTION' ;
/** the column name for the SHD_DETAILS field */
const SHD_DETAILS = 'SHADOW_TABLE.SHD_DETAILS' ;
/** the column name for the USR_UID field */
const USR_UID = 'SHADOW_TABLE.USR_UID' ;
/** the column name for the APP_UID field */
const APP_UID = 'SHADOW_TABLE.APP_UID' ;
/** the column name for the SHD_DATE field */
const SHD_DATE = 'SHADOW_TABLE.SHD_DATE' ;
/** 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 (
BasePeer :: TYPE_PHPNAME => array ( 'ShdUid' , 'AddTabUid' , 'ShdAction' , 'ShdDetails' , 'UsrUid' , 'AppUid' , 'ShdDate' , ),
BasePeer :: TYPE_COLNAME => array ( ShadowTablePeer :: SHD_UID , ShadowTablePeer :: ADD_TAB_UID , ShadowTablePeer :: SHD_ACTION , ShadowTablePeer :: SHD_DETAILS , ShadowTablePeer :: USR_UID , ShadowTablePeer :: APP_UID , ShadowTablePeer :: SHD_DATE , ),
BasePeer :: TYPE_FIELDNAME => array ( 'SHD_UID' , 'ADD_TAB_UID' , 'SHD_ACTION' , 'SHD_DETAILS' , 'USR_UID' , 'APP_UID' , 'SHD_DATE' , ),
BasePeer :: TYPE_NUM => array ( 0 , 1 , 2 , 3 , 4 , 5 , 6 , )
);
/**
* 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 (
BasePeer :: TYPE_PHPNAME => array ( 'ShdUid' => 0 , 'AddTabUid' => 1 , 'ShdAction' => 2 , 'ShdDetails' => 3 , 'UsrUid' => 4 , 'AppUid' => 5 , 'ShdDate' => 6 , ),
BasePeer :: TYPE_COLNAME => array ( ShadowTablePeer :: SHD_UID => 0 , ShadowTablePeer :: ADD_TAB_UID => 1 , ShadowTablePeer :: SHD_ACTION => 2 , ShadowTablePeer :: SHD_DETAILS => 3 , ShadowTablePeer :: USR_UID => 4 , ShadowTablePeer :: APP_UID => 5 , ShadowTablePeer :: SHD_DATE => 6 , ),
BasePeer :: TYPE_FIELDNAME => array ( 'SHD_UID' => 0 , 'ADD_TAB_UID' => 1 , 'SHD_ACTION' => 2 , 'SHD_DETAILS' => 3 , 'USR_UID' => 4 , 'APP_UID' => 5 , 'SHD_DATE' => 6 , ),
BasePeer :: TYPE_NUM => array ( 0 , 1 , 2 , 3 , 4 , 5 , 6 , )
);
/**
* @ 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/ShadowTableMapBuilder.php' ;
return BasePeer :: getMapBuilder ( 'classes.model.map.ShadowTableMapBuilder' );
}
/**
* 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 = ShadowTablePeer :: 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 . ShadowTablePeer :: COLUMN_NAME ) .
* @ return string
*/
public static function alias ( $alias , $column )
{
return str_replace ( ShadowTablePeer :: 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 )
{
$criteria -> addSelectColumn ( ShadowTablePeer :: SHD_UID );
$criteria -> addSelectColumn ( ShadowTablePeer :: ADD_TAB_UID );
$criteria -> addSelectColumn ( ShadowTablePeer :: SHD_ACTION );
$criteria -> addSelectColumn ( ShadowTablePeer :: SHD_DETAILS );
$criteria -> addSelectColumn ( ShadowTablePeer :: USR_UID );
$criteria -> addSelectColumn ( ShadowTablePeer :: APP_UID );
$criteria -> addSelectColumn ( ShadowTablePeer :: SHD_DATE );
}
const COUNT = 'COUNT(SHADOW_TABLE.SHD_UID)' ;
const COUNT_DISTINCT = 'COUNT(DISTINCT SHADOW_TABLE.SHD_UID)' ;
/**
* 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 ( ShadowTablePeer :: COUNT_DISTINCT );
} else {
$criteria -> addSelectColumn ( ShadowTablePeer :: COUNT );
}
// just in case we're grouping: add those columns to the select statement
foreach ( $criteria -> getGroupByColumns () as $column ) {
$criteria -> addSelectColumn ( $column );
}
$rs = ShadowTablePeer :: 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 ShadowTable
* @ 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 = ShadowTablePeer :: 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 ShadowTablePeer :: populateObjects ( ShadowTablePeer :: 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 ;
ShadowTablePeer :: 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 = ShadowTablePeer :: 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 ShadowTablePeer :: CLASS_DEFAULT ;
}
/**
* Method perform an INSERT on the database , given a ShadowTable or Criteria object .
*
* @ param mixed $values Criteria or ShadowTable 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 ShadowTable 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 ShadowTable or Criteria object .
*
* @ param mixed $values Criteria or ShadowTable 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
$comparison = $criteria -> getComparison ( ShadowTablePeer :: SHD_UID );
$selectCriteria -> add ( ShadowTablePeer :: SHD_UID , $criteria -> remove ( ShadowTablePeer :: SHD_UID ), $comparison );
} 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 SHADOW_TABLE 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 ( ShadowTablePeer :: TABLE_NAME , $con );
$con -> commit ();
return $affectedRows ;
} catch ( PropelException $e ) {
$con -> rollback ();
throw $e ;
}
}
/**
* Method perform a DELETE on the database , given a ShadowTable or Criteria object OR a primary key value .
*
* @ param mixed $values Criteria or ShadowTable 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 ( ShadowTablePeer :: DATABASE_NAME );
}
if ( $values instanceof Criteria ) {
$criteria = clone $values ; // rename for clarity
} elseif ( $values instanceof ShadowTable ) {
$criteria = $values -> buildPkeyCriteria ();
} else {
// it must be the primary key
$criteria = new Criteria ( self :: DATABASE_NAME );
$criteria -> add ( ShadowTablePeer :: SHD_UID , ( array ) $values , Criteria :: IN );
}
// 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 ShadowTable 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 ShadowTable $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 ( ShadowTable $obj , $cols = null )
{
$columns = array ();
if ( $cols ) {
$dbMap = Propel :: getDatabaseMap ( ShadowTablePeer :: DATABASE_NAME );
$tableMap = $dbMap -> getTable ( ShadowTablePeer :: 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 ( ShadowTablePeer :: DATABASE_NAME , ShadowTablePeer :: TABLE_NAME , $columns );
}
/**
* Retrieve a single object by pkey .
*
* @ param mixed $pk the primary key .
* @ param Connection $con the connection to use
* @ return ShadowTable
*/
public static function retrieveByPK ( $pk , $con = null )
{
if ( $con === null ) {
$con = Propel :: getConnection ( self :: DATABASE_NAME );
}
$criteria = new Criteria ( ShadowTablePeer :: DATABASE_NAME );
$criteria -> add ( ShadowTablePeer :: SHD_UID , $pk );
$v = ShadowTablePeer :: doSelect ( $criteria , $con );
return ! empty ( $v ) > 0 ? $v [ 0 ] : null ;
}
/**
* Retrieve multiple objects by pkey .
*
* @ param array $pks List of primary keys
* @ param Connection $con the connection to use
* @ throws PropelException Any exceptions caught during processing will be
* rethrown wrapped into a PropelException .
*/
public static function retrieveByPKs ( $pks , $con = null )
{
if ( $con === null ) {
$con = Propel :: getConnection ( self :: DATABASE_NAME );
}
$objs = null ;
if ( empty ( $pks )) {
$objs = array ();
} else {
$criteria = new Criteria ();
$criteria -> add ( ShadowTablePeer :: SHD_UID , $pks , Criteria :: IN );
$objs = ShadowTablePeer :: doSelect ( $criteria , $con );
}
return $objs ;
}
}
2010-12-02 23:34:41 +00: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 {
BaseShadowTablePeer :: getMapBuilder ();
} catch ( Exception $e ) {
Propel :: log ( 'Could not initialize Peer: ' . $e -> getMessage (), Propel :: LOG_ERR );
}
2010-12-02 23:34:41 +00: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/ShadowTableMapBuilder.php' ;
Propel :: registerMapBuilder ( 'classes.model.map.ShadowTableMapBuilder' );
2010-12-02 23:34:41 +00:00
}
2012-10-04 17:54:44 -04:00