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


PHP QueryBuilder::distinct方法代碼示例

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


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

示例1: applyGreatestNPerGroupDate

 public function applyGreatestNPerGroupDate(QueryBuilder $qb)
 {
     $qb->distinct();
     $qb2 = $this->createQueryBuilder('ss')->select('MAX(ss.timestamp)')->where('DATE(ss.timestamp) = DATE(s.timestamp)');
     $qb->innerJoin($this->getEntityName(), 'sub', 'WITH', $qb->expr()->eq('s.timestamp', '(' . $qb2->getDQL() . ')'));
 }
開發者ID:redelivre,項目名稱:login-cidadao,代碼行數:6,代碼來源:StatisticsRepository.php

示例2: makeDistinct

 public function makeDistinct()
 {
     $this->queryBuilder->distinct();
 }
開發者ID:animaltool,項目名稱:webinterface,代碼行數:4,代碼來源:Query.php

示例3: applyJoins

 /**
  * Applies the given joins for the query builder
  *
  * @param QueryBuilder $qb
  * @param array|null   $joins
  */
 public static function applyJoins(QueryBuilder $qb, $joins)
 {
     if (empty($joins)) {
         return;
     }
     $qb->distinct(true);
     $rootAlias = self::getSingleRootAlias($qb);
     foreach ($joins as $key => $val) {
         if (empty($val)) {
             $qb->leftJoin($rootAlias . '.' . $key, $key);
         } elseif (is_array($val)) {
             if (isset($val['join'])) {
                 $join = $val['join'];
                 if (false === strpos($join, '.')) {
                     $join = $rootAlias . '.' . $join;
                 }
             } else {
                 $join = $rootAlias . '.' . $key;
             }
             $condition = null;
             $conditionType = null;
             if (isset($val['condition'])) {
                 $condition = $val['condition'];
                 $conditionType = Expr\Join::WITH;
             }
             if (isset($val['conditionType'])) {
                 $conditionType = $val['conditionType'];
             }
             $qb->leftJoin($join, $key, $conditionType, $condition);
         } else {
             $qb->leftJoin($rootAlias . '.' . $val, $val);
         }
     }
 }
開發者ID:antrampa,項目名稱:platform,代碼行數:40,代碼來源:QueryUtils.php

示例4: parse

 /**
  * {@inheritdoc}
  */
 public function parse($value, QueryBuilder $qb)
 {
     if (!is_array($value)) {
         $value = Yaml::parse($value);
     }
     $processor = new Processor();
     $value = $processor->processConfiguration(new QueryConfiguration(), $value);
     if (!isset($value['from'])) {
         throw new \RuntimeException('Missing mandatory "from" section');
     }
     foreach ((array) $value['from'] as $from) {
         $qb->from($from['table'], $from['alias']);
     }
     if (isset($value['select'])) {
         foreach ($value['select'] as $select) {
             $qb->add('select', new Expr\Select($select), true);
         }
     }
     if (isset($value['distinct'])) {
         $qb->distinct((bool) $value['distinct']);
     }
     if (isset($value['groupBy'])) {
         $qb->groupBy($value['groupBy']);
     }
     if (isset($value['having'])) {
         $qb->having($value['having']);
     }
     $this->addJoin($qb, $value);
     $this->addWhere($qb, $value);
     $this->addOrder($qb, $value);
     return $qb;
 }
開發者ID:ashutosh-srijan,項目名稱:findit_akeneo,代碼行數:35,代碼來源:YamlConverter.php

示例5: execute

 /**
  * {@inheritdoc}
  */
 public function execute()
 {
     // emit listbuilder.create event
     $event = new ListBuilderCreateEvent($this);
     $this->eventDispatcher->dispatch(ListBuilderEvents::LISTBUILDER_CREATE, $event);
     $this->expressionFields = $this->getUniqueExpressionFieldDescriptors($this->expressions);
     // first create simplified id query
     // select ids with all necessary filter data
     $ids = $this->findIdsByGivenCriteria();
     // if no results are found - return
     if (count($ids) < 1) {
         return [];
     }
     // now select all data
     $this->queryBuilder = $this->em->createQueryBuilder()->from($this->entityName, $this->entityName);
     $this->assignJoins($this->queryBuilder);
     // Add all select fields
     foreach ($this->selectFields as $field) {
         $this->queryBuilder->addSelect($field->getSelect() . ' AS ' . $field->getName());
     }
     // group by
     $this->assignGroupBy($this->queryBuilder);
     // assign sort-fields
     $this->assignSortFields($this->queryBuilder);
     // use ids previously selected ids for query
     $select = $this->entityName . '.id';
     if (null !== $this->idField) {
         $select = $this->idField->getSelect();
     }
     $this->queryBuilder->where($select . ' IN (:ids)')->setParameter('ids', $ids);
     $this->queryBuilder->distinct($this->distinct);
     return $this->queryBuilder->getQuery()->getArrayResult();
 }
開發者ID:sulu,項目名稱:sulu,代碼行數:36,代碼來源:DoctrineListBuilder.php

示例6: __wakeup

 /**
  * Recreate query builder and set state again.
  *
  * @return void
  */
 public function __wakeup()
 {
     if ($this->constraint !== null) {
         $this->queryBuilder->where($this->constraint);
     }
     if (is_array($this->orderings)) {
         $aliases = $this->queryBuilder->getRootAliases();
         foreach ($this->orderings as $propertyName => $order) {
             $this->queryBuilder->addOrderBy($aliases[0] . '.' . $propertyName, $order);
         }
     }
     if (is_array($this->joins)) {
         foreach ($this->joins as $joinAlias => $join) {
             $this->queryBuilder->leftJoin($join, $joinAlias);
         }
     }
     $this->queryBuilder->setFirstResult($this->offset);
     $this->queryBuilder->setMaxResults($this->limit);
     $this->queryBuilder->distinct($this->distinct);
     $this->queryBuilder->setParameters($this->parameters);
     unset($this->parameters);
 }
開發者ID:mkeitsch,項目名稱:flow-development-collection,代碼行數:27,代碼來源:Query.php


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