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


PHP QueryBuilder::getEntityManager方法代碼示例

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


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

示例1: array

 /**
  * @param Repository $EntityRepository
  * @param array      $Filter array( 'ColumnName' => 'Value', ... )
  */
 function __construct(Repository $EntityRepository, $Filter = array())
 {
     $this->QueryBuilder = $EntityRepository->createQueryBuilder(self::QUERY_BUILDER_ALIAS);
     $this->ColumnNames = $this->QueryBuilder->getEntityManager()->getClassMetadata($EntityRepository->getClassName())->getFieldNames();
     $this->Request = $this->getRequest()->getParameterArray();
     $this->setFilter($Filter);
     $this->setSearch();
     $this->setOrderBy();
 }
開發者ID:BozzaCoon,項目名稱:SPHERE-Framework,代碼行數:13,代碼來源:DataTables.php

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

示例3: getFixedQueryBuilder

 /**
  * This method alters the query to return a clean set of object with a working
  * set of Object
  *
  * @param \Doctrine\ORM\QueryBuilder $queryBuilder
  * @return void
  */
 private function getFixedQueryBuilder(QueryBuilder $queryBuilder)
 {
     $queryBuilderId = clone $queryBuilder;
     // step 1 : retrieve the targeted class
     $from = $queryBuilderId->getDQLPart('from');
     $class = $from[0]->getFrom();
     // step 2 : retrieve the column id
     $idName = current($queryBuilderId->getEntityManager()->getMetadataFactory()->getMetadataFor($class)->getIdentifierFieldNames());
     // step 3 : retrieve the different subjects id
     $select = sprintf('%s.%s', $queryBuilderId->getRootAlias(), $idName);
     $queryBuilderId->resetDQLPart('select');
     $queryBuilderId->add('select', 'DISTINCT ' . $select);
     $results = $queryBuilderId->getQuery()->execute(array(), Query::HYDRATE_ARRAY);
     $idx = array();
     $connection = $queryBuilder->getEntityManager()->getConnection();
     foreach ($results as $id) {
         $idx[] = $connection->quote($id[$idName]);
     }
     // step 4 : alter the query to match the targeted ids
     if (count($idx) > 0) {
         $queryBuilder->andWhere(sprintf('%s IN (%s)', $select, implode(',', $idx)));
         $queryBuilder->setMaxResults(null);
         $queryBuilder->setFirstResult(null);
     }
     return $queryBuilder;
 }
開發者ID:renegare,項目名稱:AdminBundle,代碼行數:33,代碼來源:ProxyQuery.php

示例4: resolveEntityClass

 /**
  * Gets the full class name if the given join expression represents an entity name in form "bundle:class"
  *
  * @param string $joinExpr
  *
  * @return string
  */
 protected function resolveEntityClass($joinExpr)
 {
     $parts = explode(':', $joinExpr);
     if (count($parts) !== 2) {
         return $joinExpr;
     }
     return $this->originalQueryBuilder->getEntityManager()->getConfiguration()->getEntityNamespace($parts[0]) . '\\' . $parts[1];
 }
開發者ID:Maksold,項目名稱:platform,代碼行數:15,代碼來源:QueryOptimizationContext.php

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

示例6: initIdFieldName

 /**
  * Initialize the column id of the targeted class.
  *
  * @return string
  */
 protected function initIdFieldName()
 {
     /** @var $from \Doctrine\ORM\Query\Expr\From */
     $from = current($this->originalQb->getDQLPart('from'));
     $class = $from->getFrom();
     $idNames = $this->originalQb->getEntityManager()->getMetadataFactory()->getMetadataFor($class)->getIdentifierFieldNames();
     $this->idFieldName = current($idNames);
 }
開發者ID:northdakota,項目名稱:platform,代碼行數:13,代碼來源:CountQueryBuilderOptimizer.php

示例7: createNumRowsSubQuery

 private function createNumRowsSubQuery()
 {
     $parts = $this->query->getDQLParts();
     $from = $parts['from'][0];
     $where = $parts['where'];
     $entityManager = $this->query->getEntityManager();
     $queryBuilder = $entityManager->createQueryBuilder();
     $queryBuilder->select('COUNT(DISTINCT countAlias.id)')->from($from->getFrom(), 'countAlias');
     $aliasCount = 1;
     $aliases = array($from->getAlias() => 'countAlias');
     foreach ($parts['join'] as $joinSource => $joins) {
         if (!array_key_exists($joinSource, $aliases)) {
             $aliases[$joinSource] = 'countAlias' . $aliasCount;
             ++$aliasCount;
         }
         foreach ($joins as $join) {
             if (!array_key_exists($join->getAlias(), $aliases)) {
                 $aliases[$join->getAlias()] = 'countAlias' . $aliasCount;
                 ++$aliasCount;
             }
             preg_match('#[a-zA-Z_]*\\.+#', $join->getJoin(), $matches);
             $joinCondition = preg_replace('#[a-zA-Z_]*\\.+#', $aliases[substr($matches[0], 0, -1)] . '.', $join->getJoin());
             switch ($join->getJoinType()) {
                 case \Doctrine\ORM\Query\Expr\Join::INNER_JOIN:
                     $queryBuilder->innerJoin($joinCondition, $aliases[$join->getAlias()]);
                     break;
                 case \Doctrine\ORM\Query\Expr\Join::LEFT_JOIN:
                     $queryBuilder->leftJoin($joinCondition, $aliases[$join->getAlias()]);
                     break;
                 default:
                     throw new \Exception('Unknow join type');
                     break;
             }
         }
     }
     if ($where) {
         $whereCondition = $where->__toString();
         preg_match_all('#([a-zA-Z_]*)\\.+#', $whereCondition, $matches);
         foreach ($matches[1] as $alias) {
             $whereCondition = preg_replace('#' . $alias . '\\.+#', $aliases[$alias] . '.', $whereCondition);
         }
         $queryBuilder->where($whereCondition);
     }
     return $queryBuilder;
 }
開發者ID:w3build,項目名稱:paginate-bundle,代碼行數:45,代碼來源:QueryBuilder.php

示例8: applyToCollection

 /**
  * {@inheritdoc}
  */
 public function applyToCollection(ResourceInterface $resource, QueryBuilder $queryBuilder)
 {
     $classMetaData = $queryBuilder->getEntityManager()->getClassMetadata($resource->getEntityClass());
     $identifiers = $classMetaData->getIdentifier();
     if (null !== $this->order && 1 === count($identifiers)) {
         $identifier = $identifiers[0];
         $queryBuilder->addOrderBy('o.' . $identifier, $this->order);
     }
 }
開發者ID:akomm,項目名稱:DunglasApiBundle,代碼行數:12,代碼來源:OrderExtension.php

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

示例10: applyToCollection

 /**
  * {@inheritdoc}
  */
 public function applyToCollection(QueryBuilder $queryBuilder, QueryNameGeneratorInterface $queryNameGenerator, string $resourceClass, string $operationName = null)
 {
     $classMetaData = $queryBuilder->getEntityManager()->getClassMetadata($resourceClass);
     $identifiers = $classMetaData->getIdentifier();
     if (null !== $this->order) {
         foreach ($identifiers as $identifier) {
             $queryBuilder->addOrderBy('o.' . $identifier, $this->order);
         }
     }
 }
開發者ID:api-platform,項目名稱:core,代碼行數:13,代碼來源:OrderExtension.php

示例11: initializeDataStructure

 protected function initializeDataStructure($tableName, $primaryKey)
 {
     $dataStructure = new Structures\DataStructure($tableName, $primaryKey);
     $this->setDataStructure($dataStructure);
     $entityManager = $this->queryBuilder->getEntityManager();
     $classMetadata = $entityManager->getClassMetadata($tableName);
     Helpers::setStructureFromColumns($dataStructure, $this->determineFromColumns($classMetadata));
     foreach ($classMetadata->getAssociationNames() as $associationName) {
         $targetClass = $classMetadata->getAssociationTargetClass($associationName);
         $targetMetadata = $entityManager->getClassMetadata($targetClass);
         $associations = $classMetadata->getAssociationsByTargetClass($targetClass);
         $primaryColumns = $targetMetadata->getIdentifierColumnNames();
         foreach ($associations as $association) {
             $dataStructure->getOrCreateTableStructure($targetClass, reset($primaryColumns));
             $associationsType = $association['type'];
             if ($associationsType === $classMetadata::ONE_TO_ONE) {
                 if ($association['sourceEntity'] === $tableName) {
                     $referencedColumn = reset($association['targetToSourceKeyColumns']);
                 }
                 if (!isset($referencedColumn)) {
                     throw new InvalidStateException(sprintf('Can not find referenced column name for field %s.', $associationName));
                 }
                 $dataStructure->addOneToOne($associationName, $targetClass, $referencedColumn);
             } elseif ($associationsType === $classMetadata::MANY_TO_ONE) {
                 if ($association['sourceEntity'] === $tableName) {
                     $referencedColumn = reset($association['targetToSourceKeyColumns']);
                 }
                 if (!isset($referencedColumn)) {
                     throw new InvalidStateException(sprintf('Can not find referenced column name for field %s.', $associationName));
                 }
                 $dataStructure->addManyToOne($associationName, $targetClass, $referencedColumn);
             } elseif ($associationsType === $classMetadata::ONE_TO_MANY) {
                 foreach ($targetMetadata->getAssociationMappings() as $joinedAssociation) {
                     if ($joinedAssociation['inversedBy'] === $associationName) {
                         $referencedColumn = reset($joinedAssociation['targetToSourceKeyColumns']);
                     }
                 }
                 if (!isset($referencedColumn)) {
                     throw new InvalidStateException(sprintf('Can not find referenced column name for field %s. Is `inversedBy` set in property annotation?', $associationName));
                 }
                 $dataStructure->addOneToMany($associationName, $targetClass, $referencedColumn);
             } elseif ($associationsType === $classMetadata::MANY_TO_MANY) {
                 if (!isset($association['joinTable'])) {
                     throw new InvalidStateException(sprintf('Can not find joinColumn settings for field %s. Is `joinColumn` set in property annotation?', $associationName));
                 }
                 $joinTable = $association['joinTable'];
                 if (isset($joinTable['joinColumns']) && $joinTable['joinColumns']) {
                     $joinColumn = reset($joinTable['joinColumns']);
                     $inverseJoinColumn = reset($joinTable['inverseJoinColumns']);
                     $dataStructure->addManyToMany($associationName, $targetClass, $inverseJoinColumn['name'], $joinTable['name'], $joinColumn['name']);
                 }
             }
         }
     }
 }
開發者ID:mesour,項目名稱:sources,代碼行數:55,代碼來源:DoctrineSource.php

示例12: normalize

 /**
  * @inheritdoc
  */
 public function normalize(Query $query, QueryBuilder $queryBuilder, $hydratorClass = null)
 {
     /*
      * Add custom hydrator
      */
     $emConfig = $queryBuilder->getEntityManager()->getConfiguration();
     $hydrator = new \ReflectionClass($hydratorClass);
     $hydratorName = $hydrator->getShortName();
     $emConfig->addCustomHydrationMode($hydratorName, $hydratorClass);
     return $query->getResult($hydratorName);
 }
開發者ID:mops1k,項目名稱:KitpagesDataGridBundle,代碼行數:14,代碼來源:StandardNormalizer.php

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

示例14: joinRelations

 /**
  * Left joins relations to eager load.
  *
  * @param ResourceInterface $resource
  * @param QueryBuilder      $queryBuilder
  */
 private function joinRelations(ResourceInterface $resource, QueryBuilder $queryBuilder)
 {
     $classMetaData = $queryBuilder->getEntityManager()->getClassMetadata($resource->getEntityClass());
     foreach ($classMetaData->getAssociationNames() as $i => $association) {
         $mapping = $classMetaData->associationMappings[$association];
         if (ClassMetadataInfo::FETCH_EAGER === $mapping['fetch']) {
             $queryBuilder->leftJoin('o.' . $association, 'a' . $i);
             $queryBuilder->addSelect('a' . $i);
         }
     }
 }
開發者ID:PaskR,項目名稱:DunglasApiBundle,代碼行數:17,代碼來源:EagerLoadingExtension.php

示例15: applyAcl

 /**
  * Apply ACL restriction to query builder.
  *
  * @param QueryBuilder $queryBuilder
  * @param string $tableAlias
  */
 public function applyAcl(QueryBuilder $queryBuilder, $tableAlias)
 {
     $taggableEntities = $this->getTaggableEntities($queryBuilder->getEntityManager());
     $allowedEntities = $this->getAllowedEntities($taggableEntities);
     if (count($allowedEntities) != count($taggableEntities)) {
         if ($allowedEntities) {
             $queryBuilder->andWhere($tableAlias . '.entityName IN(:allowedEntities)')->setParameter('allowedEntities', $allowedEntities);
         } else {
             // Do not show any result if all entities are prohibited
             $queryBuilder->andWhere('1 = 0');
         }
     }
 }
開發者ID:Maksold,項目名稱:platform,代碼行數:19,代碼來源:SecurityProvider.php


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