public static function getComment($querytrackid, $featurevectortypeid, $distancetypeid, $userid = null) { if ($userid === null) { $user = sfContext::getInstance()->getUser(); $userid = $user->getAttribute('userid'); } $criteria = new Criteria(); $criteria->add(QueryCommentPeer::SMINT_USER_ID, $userid); $criteria->add(QueryCommentPeer::QUERYTRACKID, $querytrackid); $criteria->add(QueryCommentPeer::FEATUREVECTORTYPEID, $featurevectortypeid); $criteria->add(QueryCommentPeer::DISTANCETYPEID, $distancetypeid); // get querycomment $comment = QueryCommentPeer::doSelectOne($criteria); // create if querycomment does not exist already if (is_null($comment)) { $comment = new QueryComment(); $comment->setSmintUserId($userid); $comment->setQuerytrackid($querytrackid); $comment->setFeaturevectortypeid($featurevectortypeid); $comment->setDistancetypeid($distancetypeid); $comment->save(); } return $comment; }
/** * Adds an object to the instance pool. * * Propel keeps cached copies of objects in an instance pool when they are retrieved * from the database. In some cases -- especially when you override doSelect*() * methods in your stub classes -- you may need to explicitly add objects * to the cache in order to ensure that the same objects are always returned by doSelect*() * and retrieveByPK*() calls. * * @param QueryComment $value A QueryComment object. * @param string $key (optional) key to use for instance map (for performance boost if key was already calculated externally). */ public static function addInstanceToPool(QueryComment $obj, $key = null) { if (Propel::isInstancePoolingEnabled()) { if ($key === null) { $key = (string) $obj->getId(); } // if key === null self::$instances[$key] = $obj; } }
/** * Declares an association between this object and a QueryComment object. * * @param QueryComment $v * @return QueryCommentTrack The current object (for fluent API support) * @throws PropelException */ public function setQueryComment(QueryComment $v = null) { if ($v === null) { $this->setSmintQuerycommentId(NULL); } else { $this->setSmintQuerycommentId($v->getId()); } $this->aQueryComment = $v; // Add binding for other direction of this n:n relationship. // If this object has already been added to the QueryComment object, it will not be re-added. if ($v !== null) { $v->addQueryCommentTrack($this); } return $this; }