예제 #1
0
 /**
  * Method to do selects.
  *
  * @param      Criteria $criteria The Criteria object used to build the SELECT statement.
  * @param      PropelPDO $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, PropelPDO $con = null)
 {
     return PagePeer::populateObjects(PagePeer::doSelectStmt($criteria, $con));
 }
예제 #2
0
 /**
  * Reloads this object from datastore based on primary key and (optionally) resets all associated objects.
  *
  * This will only work if the object has been saved and has a valid primary key set.
  *
  * @param boolean $deep (optional) Whether to also de-associated any related objects.
  * @param PropelPDO $con (optional) The PropelPDO connection to use.
  * @return void
  * @throws PropelException - if this object is deleted, unsaved or doesn't have pk match in db
  */
 public function reload($deep = false, PropelPDO $con = null)
 {
     if ($this->isDeleted()) {
         throw new PropelException("Cannot reload a deleted object.");
     }
     if ($this->isNew()) {
         throw new PropelException("Cannot reload an unsaved object.");
     }
     if ($con === null) {
         $con = Propel::getConnection(PagePeer::DATABASE_NAME, Propel::CONNECTION_READ);
     }
     // We don't need to alter the object instance pool; we're just modifying this instance
     // already in the pool.
     $stmt = PagePeer::doSelectStmt($this->buildPkeyCriteria(), $con);
     $row = $stmt->fetch(PDO::FETCH_NUM);
     $stmt->closeCursor();
     if (!$row) {
         throw new PropelException('Cannot find matching row in the database to reload object values.');
     }
     $this->hydrate($row, 0, true);
     // rehydrate
     if ($deep) {
         // also de-associate any related objects?
         $this->aPageRelatedByCanonicalId = null;
         $this->aUserRelatedByCreatedBy = null;
         $this->aUserRelatedByUpdatedBy = null;
         $this->collPagesRelatedById = null;
         $this->collPagePropertys = null;
         $this->collPageStrings = null;
         $this->collContentObjects = null;
         $this->collRights = null;
     }
     // if (deep)
 }
예제 #3
0
 /**
  * Update the tree to allow insertion of a leaf at the specified position
  *
  * @param      PropelPDO $con	Connection to use.
  */
 public static function fixLevels(PropelPDO $con = null)
 {
     $c = new Criteria();
     $c->addAscendingOrderByColumn(PagePeer::LEFT_COL);
     $stmt = PagePeer::doSelectStmt($c, $con);
     // set the class once to avoid overhead in the loop
     $cls = PagePeer::getOMClass(false);
     $level = null;
     // iterate over the statement
     while ($row = $stmt->fetch(PDO::FETCH_NUM)) {
         // hydrate object
         $key = PagePeer::getPrimaryKeyHashFromRow($row, 0);
         if (null === ($obj = PagePeer::getInstanceFromPool($key))) {
             $obj = new $cls();
             $obj->hydrate($row);
             PagePeer::addInstanceToPool($obj, $key);
         }
         // compute level
         // Algorithm shamelessly stolen from sfPropelActAsNestedSetBehaviorPlugin
         // Probably authored by Tristan Rivoallan
         if ($level === null) {
             $level = 0;
             $i = 0;
             $prev = array($obj->getRightValue());
         } else {
             while ($obj->getRightValue() > $prev[$i]) {
                 $i--;
             }
             $level = ++$i;
             $prev[$i] = $obj->getRightValue();
         }
         // update level in node if necessary
         if ($obj->getLevel() !== $level) {
             $obj->setLevel($level);
             $obj->save($con);
         }
     }
     $stmt->closeCursor();
 }