Exemplo n.º 1
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(EspecialidadPeer::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 = EspecialidadPeer::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->collMedicos = null;
         $this->collMedicoespecialidads = null;
     }
     // if (deep)
 }
Exemplo n.º 2
0
 /**
  * Update the tree to allow insertion of a leaf at the specified position
  *
  * @param      integer $scope	scope column value
  * @param      PropelPDO $con	Connection to use.
  */
 public static function fixLevels($scope, PropelPDO $con = null)
 {
     $c = new Criteria();
     $c->add(EspecialidadPeer::SCOPE_COL, $scope, Criteria::EQUAL);
     $c->addAscendingOrderByColumn(EspecialidadPeer::LEFT_COL);
     $stmt = EspecialidadPeer::doSelectStmt($c, $con);
     // set the class once to avoid overhead in the loop
     $cls = EspecialidadPeer::getOMClass(false);
     $level = null;
     // iterate over the statement
     while ($row = $stmt->fetch(PDO::FETCH_NUM)) {
         // hydrate object
         $key = EspecialidadPeer::getPrimaryKeyHashFromRow($row, 0);
         if (null === ($obj = EspecialidadPeer::getInstanceFromPool($key))) {
             $obj = new $cls();
             $obj->hydrate($row);
             EspecialidadPeer::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();
 }
Exemplo n.º 3
0
 /**
  * Selects several row from the DB.
  *
  * @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 EspecialidadPeer::populateObjects(EspecialidadPeer::doSelectStmt($criteria, $con));
 }