/** * 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(PcUserPeer::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 = PcUserPeer::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->aPcTimezone = null; $this->collPcRemembermeKeys = null; $this->lastPcRemembermeKeyCriteria = null; $this->collPcDirtyTasks = null; $this->lastPcDirtyTaskCriteria = null; $this->singlePcFailedLogins = null; $this->singlePcActivationToken = null; $this->singlePcPasswordResetToken = null; $this->singlePcPlancakeEmailAddress = null; $this->collPcLists = null; $this->lastPcListCriteria = null; $this->collPcUsersListss = null; $this->lastPcUsersListsCriteria = null; $this->collPcEmailChangeHistorys = null; $this->lastPcEmailChangeHistoryCriteria = null; $this->collPcUsersContextss = null; $this->lastPcUsersContextsCriteria = null; $this->singlePcSupporter = null; $this->collPcBlogPosts = null; $this->lastPcBlogPostCriteria = null; $this->collPcBlogComments = null; $this->lastPcBlogCommentCriteria = null; $this->collPcApiApps = null; $this->lastPcApiAppCriteria = null; $this->collPcApiTokens = null; $this->lastPcApiTokenCriteria = null; $this->collPcNotes = null; $this->lastPcNoteCriteria = null; $this->collPcSubscriptions = null; $this->lastPcSubscriptionCriteria = null; $this->collPcGoogleCalendars = null; $this->lastPcGoogleCalendarCriteria = null; $this->singlePcUserKey = null; $this->collPcContacts = null; $this->lastPcContactCriteria = null; $this->collPcContactTags = null; $this->lastPcContactTagCriteria = null; $this->collPcContactsTagss = null; $this->lastPcContactsTagsCriteria = null; $this->collPcContactNotes = null; $this->lastPcContactNoteCriteria = null; $this->singlePcHideableHintsSetting = null; $this->collPcSplitTestUserResults = null; $this->lastPcSplitTestUserResultCriteria = null; } // if (deep) }
/** * 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 PcUserPeer::populateObjects(PcUserPeer::doSelectStmt($criteria, $con)); }