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


PHP QueryBuilder::getRootEntities方法代碼示例

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


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

示例1: addJoins

 /**
  * Add completeness joins to query builder
  *
  * @param string $completenessAlias the join alias
  * @param string $locale            the locale
  * @param sting  $scope             the scope
  *
  * @return CompletenessJoin
  */
 public function addJoins($completenessAlias, $locale, $scope)
 {
     $rootAlias = $this->qb->getRootAlias();
     $localeAlias = $completenessAlias . 'Locale';
     $channelAlias = $completenessAlias . 'Channel';
     $rootEntity = current($this->qb->getRootEntities());
     $completenessMapping = $this->qb->getEntityManager()->getClassMetadata($rootEntity)->getAssociationMapping('completenesses');
     $completenessClass = $completenessMapping['targetEntity'];
     $this->qb->leftJoin('PimCatalogBundle:Locale', $localeAlias, 'WITH', $localeAlias . '.code = :cLocaleCode')->leftJoin('PimCatalogBundle:Channel', $channelAlias, 'WITH', $channelAlias . '.code = :cScopeCode')->leftJoin($completenessClass, $completenessAlias, 'WITH', $completenessAlias . '.locale = ' . $localeAlias . '.id AND ' . $completenessAlias . '.channel = ' . $channelAlias . '.id AND ' . $completenessAlias . '.product = ' . $rootAlias . '.id')->setParameter('cLocaleCode', $locale)->setParameter('cScopeCode', $scope);
     return $this;
 }
開發者ID:abdeldayem,項目名稱:pim-community-dev,代碼行數:20,代碼來源:CompletenessJoin.php

示例2: resetBuilder

 protected function resetBuilder()
 {
     $rootEntities = $this->qb->getRootEntities();
     $this->qb = $this->qb->getEntityManager()->getRepository($rootEntities[0])->createQueryBuilder('x');
     $this->joinAliases = [];
     $this->parametersMap = [];
     $this->orderBy = [];
 }
開發者ID:bitecodes,項目名稱:doctrine-filter,代碼行數:8,代碼來源:FilterBuilder.php

示例3: addJoins

 /**
  * Add completeness joins to query builder
  *
  * @param string $completenessAlias the join alias
  * @param string $locale            the locale
  * @param string $scope             the scope
  *
  * @return CompletenessJoin
  */
 public function addJoins($completenessAlias, $locale, $scope)
 {
     $rootAlias = $this->qb->getRootAliases()[0];
     $localeAlias = $completenessAlias . 'Locale';
     $channelAlias = $completenessAlias . 'Channel';
     $rootEntity = $this->qb->getRootEntities()[0];
     $completenessMapping = $this->qb->getEntityManager()->getClassMetadata($rootEntity)->getAssociationMapping('completenesses');
     $completenessClass = $completenessMapping['targetEntity'];
     $joinCondition = sprintf('%s.product = %s.id', $completenessAlias, $rootAlias);
     $this->qb->leftJoin('PimCatalogBundle:Channel', $channelAlias, 'WITH', $channelAlias . '.code = :cScopeCode')->setParameter('cScopeCode', $scope);
     $joinCondition .= sprintf(' AND %s.channel = %s.id', $completenessAlias, $channelAlias);
     if (null !== $locale) {
         $this->qb->leftJoin('PimCatalogBundle:Locale', $localeAlias, 'WITH', sprintf('%s.code = :%scLocaleCode', $localeAlias, $localeAlias))->setParameter($localeAlias . 'cLocaleCode', $locale);
         $joinCondition .= sprintf(' AND %s.locale = %s.id', $completenessAlias, $localeAlias);
     }
     $this->qb->leftJoin($completenessClass, $completenessAlias, 'WITH', $joinCondition);
     return $this;
 }
開發者ID:a2xchip,項目名稱:pim-community-dev,代碼行數:27,代碼來源:CompletenessJoin.php

示例4: __construct

 /**
  * @param QueryBuilder      $queryBuilder
  * @param QueryBuilderTools $qbTools
  */
 public function __construct(QueryBuilder $queryBuilder, QueryBuilderTools $qbTools)
 {
     // make sure 'from' DQL part is initialized for both original and optimized query builders
     $queryBuilder->getRootEntities();
     $this->originalQueryBuilder = $queryBuilder;
     $this->qbTools = $qbTools;
     // initialize the query builder helper
     $this->qbTools->prepareFieldAliases($this->originalQueryBuilder->getDQLPart('select'));
     $this->qbTools->prepareJoinTablePaths($this->originalQueryBuilder->getDQLPart('join'));
 }
開發者ID:Maksold,項目名稱:platform,代碼行數:14,代碼來源:QueryOptimizationContext.php

示例5: hasRootEntityWithIdentifier

 /**
  * Detects if the root entity has the given identifier.
  *
  * @param QueryBuilder    $queryBuilder
  * @param ManagerRegistry $managerRegistry
  * @param bool            $isForeign
  *
  * @return bool
  */
 private static function hasRootEntityWithIdentifier(QueryBuilder $queryBuilder, ManagerRegistry $managerRegistry, bool $isForeign) : bool
 {
     foreach ($queryBuilder->getRootEntities() as $rootEntity) {
         $rootMetadata = $managerRegistry->getManagerForClass($rootEntity)->getClassMetadata($rootEntity);
         if ($isForeign ? $rootMetadata->isIdentifierComposite : $rootMetadata->containsForeignIdentifier) {
             return true;
         }
     }
     return false;
 }
開發者ID:api-platform,項目名稱:core,代碼行數:19,代碼來源:QueryChecker.php

示例6: hasRootEntityWithForeignKeyIdentifier

 /**
  * Determines whether the query builder has any root entity with foreign key identifier.
  *
  * @param QueryBuilder    $queryBuilder
  * @param ManagerRegistry $managerRegistry
  *
  * @return bool
  */
 public static function hasRootEntityWithForeignKeyIdentifier(QueryBuilder $queryBuilder, ManagerRegistry $managerRegistry)
 {
     foreach ($queryBuilder->getRootEntities() as $rootEntity) {
         $rootMetadata = $managerRegistry->getManagerForClass($rootEntity)->getClassMetadata($rootEntity);
         if ($rootMetadata->containsForeignIdentifier) {
             return true;
         }
     }
     return false;
 }
開發者ID:akomm,項目名稱:DunglasApiBundle,代碼行數:18,代碼來源:QueryChecker.php

示例7: getAllClassesForQueryBuilder

 public function getAllClassesForQueryBuilder(QueryBuilder $queryBuilder) : array
 {
     $classes = [];
     $rootEntities = $queryBuilder->getRootEntities();
     foreach ($rootEntities as $rootEntity) {
         $classes[$rootEntity] = $rootEntity;
         $metadata = $this->getClassMetadata($rootEntity);
         $this->addAssociationsTargetClasses($metadata, $classes);
     }
     return $classes;
 }
開發者ID:WellCommerce,項目名稱:DoctrineBundle,代碼行數:11,代碼來源:DoctrineHelper.php

示例8: ensureInitialized

 /**
  * Ensure that filtering applied and query builder wrapped in buffered iterator
  * if data source is query builder or just an entity name
  *
  * @param ContextInterface $context
  */
 protected function ensureInitialized(ContextInterface $context)
 {
     if (null !== $this->qb) {
         if ($context->hasOption(self::ID_FILTER)) {
             $optionValue = $context->getOption(self::ID_FILTER);
             $em = $this->qb->getEntityManager();
             $entityNames = $this->qb->getRootEntities();
             $classMetadata = $em->getClassMetadata(reset($entityNames));
             $identifier = $classMetadata->getSingleIdentifierFieldName();
             if (is_array($optionValue)) {
                 $this->qb->andWhere($this->qb->expr()->in('o.' . $identifier, ':id'));
                 $this->qb->setParameter('id', $optionValue);
             } else {
                 $this->qb->andWhere('o.' . $identifier . ' = :id');
             }
             $this->qb->setParameter('id', $optionValue);
         }
         $this->setSourceIterator(new BufferedQueryResultIterator($this->qb));
     }
 }
開發者ID:ramunasd,項目名稱:platform,代碼行數:26,代碼來源:EntityReaderById.php

示例9: addJoinsToQueryBuilder

 private function addJoinsToQueryBuilder($alias, QueryBuilder $qb, $className, $recursive = true)
 {
     foreach ($this->getEntityManager()->getClassMetadata($className)->getAssociationMappings() as $assoc) {
         if (in_array($assoc['targetEntity'], $qb->getRootEntities()) || $className === $assoc['targetEntity']) {
             continue;
         }
         $uniqueJoinAlias = $this->getUniqueAlias($assoc['targetEntity'], $qb);
         $qb->addSelect($uniqueJoinAlias)->leftJoin(sprintf('%s.%s', $alias, $assoc['fieldName']), $uniqueJoinAlias);
         if ($recursive) {
             $this->addJoinsToQueryBuilder($uniqueJoinAlias, $qb, $assoc['targetEntity']);
         }
     }
 }
開發者ID:adampiotrowski,項目名稱:DoctrineBehaviors,代碼行數:13,代碼來源:JoinableRepository.php

示例10: setDefaultIdentifierFieldNames

 /**
  * Defines default identifiers from query builder in order to optimize count queries.
  *
  * @return $this
  *
  * @throws \Doctrine\Common\Persistence\Mapping\MappingException
  */
 public function setDefaultIdentifierFieldNames()
 {
     //Default identifier for table rows
     $rootEntity = $this->queryBuilder->getRootEntities()[0];
     $metadata = $this->queryBuilder->getEntityManager()->getMetadataFactory()->getMetadataFor($rootEntity);
     $identifiers = array();
     foreach ($metadata->getIdentifierFieldNames() as $identifierFieldName) {
         $identifiers[] = $this->getAlias() . '.' . $identifierFieldName;
     }
     $rootEntityIdentifier = implode(',', $identifiers);
     $this->setIdentifierFieldNames($rootEntityIdentifier ?: null);
     return $this;
 }
開發者ID:KilikFr,項目名稱:TableBundle,代碼行數:20,代碼來源:Table.php

示例11:

 function it_adds_a_filter_on_a_field_in_the_query(QueryBuilder $qb, Expr $expr, EntityManager $em, ClassMetadata $cm, Expr\Comparison $comparison)
 {
     $qb->expr()->willReturn($expr);
     $qb->getRootAlias()->willReturn('p');
     $qb->getRootEntities()->willReturn([]);
     $qb->getEntityManager()->willReturn($em);
     $em->getClassMetadata(false)->willReturn($cm);
     $comparison->__toString()->willReturn('filterCompleteness.ratio < 100');
     $cm->getAssociationMapping('completenesses')->willReturn(['targetEntity' => 'test']);
     $expr->literal('100')->willReturn('100');
     $expr->lt(Argument::any(), '100')->willReturn($comparison);
     $this->setQueryBuilder($qb);
     $qb->leftJoin('PimCatalogBundle:Locale', Argument::any(), 'WITH', Argument::any())->willReturn($qb);
     $qb->leftJoin('PimCatalogBundle:Channel', Argument::any(), 'WITH', Argument::any())->willReturn($qb);
     $qb->leftJoin('test', Argument::any(), 'WITH', Argument::any())->willReturn($qb);
     $qb->setParameter('cLocaleCode', Argument::any())->willReturn($qb);
     $qb->setParameter('cScopeCode', Argument::any())->willReturn($qb);
     $qb->andWhere('filterCompleteness.ratio < 100')->shouldBeCalled();
     $this->addFieldFilter('completeness', '<', 100, 'en_US', 'mobile');
 }
開發者ID:noglitchyo,項目名稱:pim-community-dev,代碼行數:20,代碼來源:CompletenessFilterSpec.php

示例12: __construct

 /**
  * Constructor.
  *
  * @param Query|QueryBuilder $query
  *        	A Doctrine ORM query or query builder.
  * @param boolean $fetchJoinCollection
  *        	Whether the query joins a collection (true by default).
  * @param boolean $cache
  *        	Use result cache (true by default).
  * @param boolean $count
  *        	Execute count query (true by default).
  */
 public function __construct($query, $fetchJoinCollection = true, $cached = true, $count = true)
 {
     if ($count) {
         $countQuery = clone $query;
         $countQuery = $countQuery->select('count(e) as c')->setFirstResult(0)->setMaxResults(1)->getQuery();
         $this->countQuery = $countQuery;
     }
     $q = $query;
     if ($cached) {
         $this->cache_prefix = '';
         if ($query instanceof QueryBuilder) {
             $q = $query->getQuery();
             $entities = $query->getRootEntities();
             if ($entities) {
                 $entity = $entities[0];
                 $this->cache_prefix = strtolower(substr(strrchr($entity, '\\'), 1) ?: $entity) . '-';
             }
         }
         $q->useQueryCache(true)->useResultCache(true, 3600, $this->cache_prefix . md5($q->getDQL()));
     }
     parent::__construct($q, $fetchJoinCollection);
 }
開發者ID:arstropica,項目名稱:zf2-dashboard,代碼行數:34,代碼來源:Paginator.php

示例13: joinACL

 /**
  * Joins with the authorizations and filters the results to keep only those authorized.
  *
  * @param QueryBuilder              $qb
  * @param SecurityIdentityInterface $identity
  * @param string                    $action
  * @param string|null               $entityClass Class name of the entity that is the resource in the query.
  *                                               If omitted, it will be guessed from the SELECT.
  * @param string|null               $entityAlias Alias of the entity that is the resource in the query.
  *                                               If omitted, it will be guessed from the SELECT.
  *
  * @throws \RuntimeException The query builder has no "select" part
  */
 public static function joinACL(QueryBuilder $qb, SecurityIdentityInterface $identity, $action, $entityClass = null, $entityAlias = null)
 {
     if ($entityClass === null) {
         $rootEntities = $qb->getRootEntities();
         if (!isset($rootEntities[0])) {
             throw new \RuntimeException('The query builder has no "select" part');
         }
         $entityClass = $rootEntities[0];
     }
     if ($entityAlias === null) {
         $rootAliases = $qb->getRootAliases();
         if (!isset($rootAliases[0])) {
             throw new \RuntimeException('The query builder has no "select" part');
         }
         $entityAlias = $rootAliases[0];
     }
     $qb->innerJoin('MyCLabs\\ACL\\Model\\Authorization', 'authorization', 'WITH', $entityAlias . '.id = authorization.entityId');
     $qb->andWhere('authorization.entityClass = :acl_entity_class');
     $qb->andWhere('authorization.securityIdentity = :acl_identity');
     $qb->andWhere('authorization.actions.' . $action . ' = true');
     $qb->setParameter('acl_identity', $identity);
     $qb->setParameter('acl_entity_class', $entityClass);
 }
開發者ID:gbelmm,項目名稱:ACL,代碼行數:36,代碼來源:ACLQueryHelper.php

示例14: getClassMetadataFromJoinAlias

 /**
  * Gets the class metadata from a given join alias.
  *
  * @param string          $alias
  * @param QueryBuilder    $queryBuilder
  * @param ManagerRegistry $managerRegistry
  *
  * @return ClassMetadata
  */
 public static function getClassMetadataFromJoinAlias(string $alias, QueryBuilder $queryBuilder, ManagerRegistry $managerRegistry) : ClassMetadata
 {
     $rootEntities = $queryBuilder->getRootEntities();
     $rootAliases = $queryBuilder->getRootAliases();
     $joinParts = $queryBuilder->getDQLPart('join');
     $aliasMap = [];
     $targetAlias = $alias;
     foreach ($joinParts as $rootAlias => $joins) {
         $aliasMap[$rootAlias] = 'root';
         foreach ($joins as $join) {
             $alias = self::getJoinAlias($join);
             $relationship = self::getJoinRelationship($join);
             $pos = strpos($relationship, '.');
             $aliasMap[$alias] = ['parentAlias' => substr($relationship, 0, $pos), 'association' => substr($relationship, $pos + 1)];
         }
     }
     $associationStack = [];
     $rootAlias = null;
     while (null === $rootAlias) {
         $mapping = $aliasMap[$targetAlias];
         if ('root' === $mapping) {
             $rootAlias = $targetAlias;
         } else {
             $associationStack[] = $mapping['association'];
             $targetAlias = $mapping['parentAlias'];
         }
     }
     $rootEntity = $rootEntities[array_search($rootAlias, $rootAliases)];
     $rootMetadata = $managerRegistry->getManagerForClass($rootEntity)->getClassMetadata($rootEntity);
     $metadata = $rootMetadata;
     while (null !== ($association = array_pop($associationStack))) {
         $associationClass = $metadata->getAssociationTargetClass($association);
         $metadata = $managerRegistry->getManagerForClass($associationClass)->getClassMetadata($associationClass);
     }
     return $metadata;
 }
開發者ID:api-platform,項目名稱:core,代碼行數:45,代碼來源:QueryJoinParser.php

示例15: buildWithSubQuery

 /**
  * Get the results from the sql after adding the
  *
  * @param \Victoire\Bundle\BusinessEntityPageBundle\Entity\BusinessEntityPagePattern $containerEntity
  * @param QueryBuilder                                                               $itemsQueryBuilder
  *
  * @throws \Exception
  *
  * @return QueryBuilder The QB to list of objects
  */
 public function buildWithSubQuery($containerEntity, QueryBuilder $itemsQueryBuilder)
 {
     //services
     $entityManager = $this->entityManager;
     //test the container entity
     if ($containerEntity === null) {
         throw new \Exception('The container entity parameter must not be null.');
     }
     //verify that the object has the query trait
     $this->checkObjectHasQueryTrait($containerEntity);
     //get the query of the container entity
     $query = $containerEntity->getQuery();
     if ($query !== '' && $query !== null) {
         $subQuery = $this->entityManager->createQueryBuilder()->select('item.id')->from($itemsQueryBuilder->getRootEntities()[0], 'item');
         $itemsQueryBuilder->andWhere('main_item.id IN (' . $subQuery->getQuery()->getDql() . ' ' . $query . ')');
     }
     $currentView = $this->currentView;
     // If the current page is a BEP, we parse all its properties and inject them as query parameters
     if ($currentView() && $currentView() instanceof BusinessEntityPage && null !== ($currentEntity = $currentView()->getBusinessEntity())) {
         // NEW
         $metadatas = $this->entityManager->getClassMetadata(get_class($currentEntity));
         foreach ($metadatas->fieldMappings as $fieldName => $field) {
             if (strpos($query, ":" . $fieldName) !== false) {
                 $itemsQueryBuilder->setParameter($fieldName, $metadatas->getFieldValue($currentEntity, $fieldName));
             }
         }
         foreach ($metadatas->associationMappings as $fieldName => $field) {
             if (strpos($query, ":" . $fieldName) !== false) {
                 $itemsQueryBuilder->setParameter($fieldName, $metadatas->getFieldValue($currentEntity, $fieldName)->getId());
             }
         }
         if (strpos($query, ":currentEntity") !== false) {
             $itemsQueryBuilder->setParameter('currentEntity', $currentEntity->getId());
         }
     }
     return $itemsQueryBuilder;
 }
開發者ID:Atc-it,項目名稱:victoire,代碼行數:47,代碼來源:QueryHelper.php


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