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


PHP QueryBuilder::groupBy方法代碼示例

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


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

示例1: modify

 /**
  * @param QueryBuilder $qb
  * @param string       $dqlAlias
  */
 public function modify(QueryBuilder $qb, $dqlAlias)
 {
     if ($this->dqlAlias !== null) {
         $dqlAlias = $this->dqlAlias;
     }
     $qb->groupBy(sprintf('%s.%s', $dqlAlias, $this->field));
 }
開發者ID:kgilden,項目名稱:Doctrine-Specification,代碼行數:11,代碼來源:GroupBy.php

示例2: createQueryBuilder

 /**
  * @return \Doctrine\ORM\QueryBuilder
  */
 private function createQueryBuilder()
 {
     $this->queryBuilder = $this->em->createQueryBuilder()->from($this->entityName, $this->entityName);
     foreach ($this->getJoins() as $entity => $join) {
         switch ($join->getJoinMethod()) {
             case DoctrineJoinDescriptor::JOIN_METHOD_LEFT:
                 $this->queryBuilder->leftJoin($join->getJoin(), $entity, $join->getJoinConditionMethod(), $join->getJoinCondition());
                 break;
             case DoctrineJoinDescriptor::JOIN_METHOD_INNER:
                 $this->queryBuilder->innerJoin($join->getJoin(), $entity, $join->getJoinConditionMethod(), $join->getJoinCondition());
                 break;
         }
     }
     // set where
     if (!empty($this->whereFields)) {
         $this->addWheres($this->whereFields, $this->whereValues, self::WHERE_COMPARATOR_EQUAL);
     }
     // set where not
     if (!empty($this->whereNotFields)) {
         $this->addWheres($this->whereNotFields, $this->whereNotValues, self::WHERE_COMPARATOR_UNEQUAL);
     }
     if (!empty($this->groupByFields)) {
         foreach ($this->groupByFields as $fields) {
             $this->queryBuilder->groupBy($fields->getSelect());
         }
     }
     // set in
     if (!empty($this->inFields)) {
         $this->addIns($this->inFields, $this->inValues);
     }
     // set between
     if (!empty($this->betweenFields)) {
         $this->addBetweens($this->betweenFields, $this->betweenValues);
     }
     if ($this->search != null) {
         $searchParts = [];
         foreach ($this->searchFields as $searchField) {
             $searchParts[] = $searchField->getSelect() . ' LIKE :search';
         }
         $this->queryBuilder->andWhere('(' . implode(' OR ', $searchParts) . ')');
         $this->queryBuilder->setParameter('search', '%' . $this->search . '%');
     }
     return $this->queryBuilder;
 }
開發者ID:kriswillis,項目名稱:sulu,代碼行數:47,代碼來源:DoctrineListBuilder.php

示例3: returnFilteredEntities

 /**
  * @param QueryBuilder $builder
  * @param AbstractFilter $filter
  * @param $groupBy
  *
  * @return array|Paginator
  */
 public function returnFilteredEntities(QueryBuilder $builder, AbstractFilter $filter, $groupBy)
 {
     $pagination = $filter->getPagination();
     if ($pagination->getLimit()) {
         $builder->setMaxResults($pagination->getLimit());
     }
     $builder->setFirstResult($pagination->getOffset());
     if ($pagination->isEnabled()) {
         $query = $builder->getQuery();
         $query->setHydrationMode($filter->getHydrationMode());
         $paginator = new Paginator($query, true);
         $pagination->setTotalResults(count($paginator));
         return $paginator;
     }
     $builder->groupBy($groupBy);
     $query = $builder->getQuery();
     $entities = $query->getResult($filter->getHydrationMode());
     return $entities;
 }
開發者ID:wucdbm,項目名稱:wucdbm-bundle,代碼行數:26,代碼來源:AbstractRepository.php

示例4: getCountFilteredResults

 /**
  * Query results after filtering.
  *
  * @param integer $rootEntityIdentifier
  * @param bool    $buildQuery
  *
  * @return int
  */
 private function getCountFilteredResults($rootEntityIdentifier, $buildQuery = true)
 {
     if (true === $buildQuery) {
         $qb = $this->em->createQueryBuilder();
         $qb->select('count(distinct ' . $this->tableName . '.' . $rootEntityIdentifier . ')');
         $qb->from($this->entity, $this->tableName);
         $this->setLeftJoins($qb);
         $this->setWhere($qb);
         $this->setWhereAllCallback($qb);
         return (int) $qb->getQuery()->getSingleScalarResult();
     } else {
         $this->qb->setFirstResult(null)->setMaxResults(null)->select('count(distinct ' . $this->tableName . '.' . $rootEntityIdentifier . ')');
         if (true === $this->isPostgreSQLConnection) {
             $this->qb->groupBy($this->tableName . '.' . $rootEntityIdentifier);
             return count($this->qb->getQuery()->getResult());
         } else {
             return (int) $this->qb->getQuery()->getSingleScalarResult();
         }
     }
 }
開發者ID:robinvliz,項目名稱:DatatablesBundle,代碼行數:28,代碼來源:DatatableQuery.php

示例5: getDataQuery

 /**
  * Build the data query
  *
  * @return QueryBuilder
  */
 public function getDataQuery()
 {
     $this->buildFilteredQuery();
     if ($this->offset !== null) {
         $this->currentQueryBuilder->setFirstResult($this->offset);
     }
     if ($this->length !== null) {
         $this->currentQueryBuilder->setMaxResults($this->length);
     }
     if ($this->orders !== null) {
         foreach ($this->orders as $order) {
             list($column, $dir) = $order;
             $this->currentQueryBuilder->addOrderBy($column->sourceSort, $dir);
         }
     }
     if (isset($this->conf->group)) {
         $this->currentQueryBuilder->groupBy($this->conf->group);
     }
     return $this->currentQueryBuilder;
 }
開發者ID:solire,項目名稱:trieur,代碼行數:25,代碼來源:DoctrineOrm.php

示例6: groupBy

 /**
  * @param array $constraints
  * @param       $queryBuilder
  * @param       $alias
  */
 public function groupBy(array &$constraints, QueryBuilder $queryBuilder, $alias)
 {
     $this->ensuresHasArrayValue($constraints, 'grouping_columns');
     $groupedColumns = $constraints['grouping_columns'];
     foreach ($groupedColumns as $column) {
         $queryBuilder->groupBy($alias . '.' . $column);
     }
     unset($constraints['grouping_columns']);
 }
開發者ID:WeavingTheWeb,項目名稱:devobs,代碼行數:14,代碼來源:QueryFactory.php

示例7: assignGroupBy

 /**
  * Sets group by fields to querybuilder.
  *
  * @param QueryBuilder $queryBuilder
  */
 protected function assignGroupBy($queryBuilder)
 {
     if (!empty($this->groupByFields)) {
         foreach ($this->groupByFields as $fields) {
             $queryBuilder->groupBy($fields->getSelect());
         }
     }
 }
開發者ID:ollietb,項目名稱:sulu,代碼行數:13,代碼來源:DoctrineListBuilder.php

示例8: setGroupBy

 /**
  * set query group
  * 
  * @param string $group
  * 
  * @return Datatable 
  */
 public function setGroupBy($group)
 {
     $this->queryBuilder->groupBy($group);
     return $this;
 }
開發者ID:tiraeth,項目名稱:AliDatatableBundle,代碼行數:12,代碼來源:DoctrineBuilder.php

示例9: applyGroupBy

 private function applyGroupBy(QueryBuilderFilter $filter, QueryBuilder $queryBuilder)
 {
     if ($filter->getGroupBy()) {
         $queryBuilder->groupBy($filter->getGroupBy());
     }
 }
開發者ID:netucz,項目名稱:slovicka,代碼行數:6,代碼來源:QueryBuilderFilterApplier.php

示例10: getGroupByStatement

 /**
  * Group By
  * @param \Doctrine\ORM\QueryBuilder $queryBuilder
  * @param array $request
  */
 private function getGroupByStatement(\Doctrine\ORM\QueryBuilder $queryBuilder)
 {
     if ($this->groupBy !== '') {
         $queryBuilder->groupBy($this->groupBy);
     }
 }
開發者ID:SylvainSimon,項目名稱:Metinify,代碼行數:11,代碼來源:DataTable.php

示例11: prepareCndPaGroupBy

 /**
  * Prepare certain search condition
  *
  * @param \Doctrine\ORM\QueryBuilder $queryBuilder Query builder to prepare
  * @param string                     $value        Parameter for GROUP BY
  *
  * @return void
  */
 protected function prepareCndPaGroupBy(\Doctrine\ORM\QueryBuilder $queryBuilder, $value)
 {
     $queryBuilder->groupBy($value);
 }
開發者ID:kirkbauer2,項目名稱:kirkxc,代碼行數:12,代碼來源:Product.php

示例12: 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


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