本文整理汇总了PHP中sfGuardGroupPermissionPeer::clearRelatedInstancePool方法的典型用法代码示例。如果您正苦于以下问题:PHP sfGuardGroupPermissionPeer::clearRelatedInstancePool方法的具体用法?PHP sfGuardGroupPermissionPeer::clearRelatedInstancePool怎么用?PHP sfGuardGroupPermissionPeer::clearRelatedInstancePool使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类sfGuardGroupPermissionPeer
的用法示例。
在下文中一共展示了sfGuardGroupPermissionPeer::clearRelatedInstancePool方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。
示例1: doDelete
/**
* Method perform a DELETE on the database, given a sfGuardGroupPermission or Criteria object OR a primary key value.
*
* @param mixed $values Criteria or sfGuardGroupPermission object or primary key or array of primary keys
* which is used to create the DELETE statement
* @param PropelPDO $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, PropelPDO $con = null)
{
if ($con === null) {
$con = Propel::getConnection(sfGuardGroupPermissionPeer::DATABASE_NAME, Propel::CONNECTION_WRITE);
}
if ($values instanceof Criteria) {
// invalidate the cache for all objects of this type, since we have no
// way of knowing (without running a query) what objects should be invalidated
// from the cache based on this Criteria.
sfGuardGroupPermissionPeer::clearInstancePool();
// rename for clarity
$criteria = clone $values;
} elseif ($values instanceof sfGuardGroupPermission) {
// it's a model object
// invalidate the cache for this single object
sfGuardGroupPermissionPeer::removeInstanceFromPool($values);
// create criteria based on pk values
$criteria = $values->buildPkeyCriteria();
} else {
// it's a primary key, or an array of pks
$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);
}
foreach ($values as $value) {
$criterion = $criteria->getNewCriterion(sfGuardGroupPermissionPeer::GROUP_ID, $value[0]);
$criterion->addAnd($criteria->getNewCriterion(sfGuardGroupPermissionPeer::PERMISSION_ID, $value[1]));
$criteria->addOr($criterion);
// we can invalidate the cache for this single PK
sfGuardGroupPermissionPeer::removeInstanceFromPool($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->beginTransaction();
$affectedRows += BasePeer::doDelete($criteria, $con);
sfGuardGroupPermissionPeer::clearRelatedInstancePool();
$con->commit();
return $affectedRows;
} catch (PropelException $e) {
$con->rollBack();
throw $e;
}
}