當前位置: 首頁>>代碼示例>>PHP>>正文


PHP ModelCriteria::mergeWith方法代碼示例

本文整理匯總了PHP中ModelCriteria::mergeWith方法的典型用法代碼示例。如果您正苦於以下問題:PHP ModelCriteria::mergeWith方法的具體用法?PHP ModelCriteria::mergeWith怎麽用?PHP ModelCriteria::mergeWith使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在ModelCriteria的用法示例。


在下文中一共展示了ModelCriteria::mergeWith方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: testMergeWithWiths

 public function testMergeWithWiths()
 {
     $c1 = new ModelCriteria('bookstore', 'Book', 'b');
     $c1->leftJoinWith('b.Author a');
     $c2 = new ModelCriteria('bookstore', 'Author');
     $c1->mergeWith($c2);
     $with = $c1->getWith();
     $this->assertEquals(1, count($with), 'mergeWith() does not remove an existing join');
     $this->assertEquals('LEFT JOIN : book.AUTHOR_ID=a.ID(ignoreCase not considered) tableMap: AuthorTableMap relationMap: Author previousJoin: null relationAlias: a', $with['a']->__toString(), 'mergeWith() does not remove an existing join');
     $c1 = new ModelCriteria('bookstore', 'Book', 'b');
     $c2 = new ModelCriteria('bookstore', 'Book', 'b');
     $c2->leftJoinWith('b.Author a');
     $c1->mergeWith($c2);
     $with = $c1->getWith();
     $this->assertEquals(1, count($with), 'mergeWith() merge joins to an empty join');
     $this->assertEquals('LEFT JOIN : book.AUTHOR_ID=a.ID(ignoreCase not considered) tableMap: AuthorTableMap relationMap: Author previousJoin: null relationAlias: a', $with['a']->__toString(), 'mergeWith() merge joins to an empty join');
     $c1 = new ModelCriteria('bookstore', 'Book', 'b');
     $c1->leftJoinWith('b.Author a');
     $c2 = new ModelCriteria('bookstore', 'Book', 'b');
     $c2->innerJoinWith('b.Publisher p');
     $c1->mergeWith($c2);
     $with = $c1->getWith();
     $this->assertEquals(2, count($with), 'mergeWith() merge joins to an existing join');
     $this->assertEquals('LEFT JOIN : book.AUTHOR_ID=a.ID(ignoreCase not considered) tableMap: AuthorTableMap relationMap: Author previousJoin: null relationAlias: a', $with['a']->__toString(), 'mergeWith() merge joins to an empty join');
     $this->assertEquals('INNER JOIN : book.PUBLISHER_ID=p.ID(ignoreCase not considered) tableMap: PublisherTableMap relationMap: Publisher previousJoin: null relationAlias: p', $with['p']->__toString(), 'mergeWith() merge joins to an empty join');
 }
開發者ID:nextbigsound,項目名稱:propel-orm,代碼行數:26,代碼來源:ModelCriteriaTest.php

示例2: __construct

 /**
  * Constructor.
  *
  * @see ModelType How to use the preferred choices.
  *
  * @param string                    $class            The FQCN of the model class to be loaded.
  * @param string                    $labelPath        A property path pointing to the property used for the choice labels.
  * @param array                     $choices          An optional array to use, rather than fetching the models.
  * @param \ModelCriteria            $queryObject      The query to use retrieving model data from database.
  * @param string                    $groupPath        A property path pointing to the property used to group the choices.
  * @param array|\ModelCriteria      $preferred        The preferred items of this choice.
  *                                                    Either an array if $choices is given,
  *                                                    or a \ModelCriteria to be merged with the $queryObject.
  * @param PropertyAccessorInterface $propertyAccessor The reflection graph for reading property paths.
  * @param string                    $useAsIdentifier  a custom unique column (eg slug) to use instead of primary key.
  *
  * @throws MissingOptionsException In case the class parameter is empty.
  * @throws InvalidOptionsException In case the query class is not found.
  */
 public function __construct($class, $labelPath = null, $choices = null, $queryObject = null, $groupPath = null, $preferred = array(), PropertyAccessorInterface $propertyAccessor = null, $useAsIdentifier = null)
 {
     $this->class = $class;
     $queryClass = $this->class . 'Query';
     if (!class_exists($queryClass)) {
         if (empty($this->class)) {
             throw new MissingOptionsException('The "class" parameter is empty, you should provide the model class');
         }
         throw new InvalidOptionsException(sprintf('The query class "%s" is not found, you should provide the FQCN of the model class', $queryClass));
     }
     $query = new $queryClass();
     $this->query = $queryObject ?: $query;
     if ($useAsIdentifier) {
         $this->identifier = array($this->query->getTableMap()->getColumn($useAsIdentifier));
     } else {
         $this->identifier = $this->query->getTableMap()->getPrimaryKeys();
     }
     $this->loaded = is_array($choices) || $choices instanceof \Traversable;
     if ($preferred instanceof \ModelCriteria) {
         $this->preferredQuery = $preferred->mergeWith($this->query);
     }
     if (!$this->loaded) {
         // Make sure the constraints of the parent constructor are
         // fulfilled
         $choices = array();
         $preferred = array();
     }
     if (1 === count($this->identifier) && $this->isScalar(current($this->identifier))) {
         $this->identifierAsIndex = true;
     }
     parent::__construct($choices, $labelPath, $preferred, $groupPath, null, $propertyAccessor);
 }
開發者ID:nibsirahsieu,項目名稱:propel1-bridge,代碼行數:51,代碼來源:ModelChoiceList.php


注:本文中的ModelCriteria::mergeWith方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。