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


PHP EntityManagerInterface::createQuery方法代碼示例

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


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

示例1: testImportExport

 /**
  * @medium
  */
 public function testImportExport()
 {
     $sourceStorage = new LocalFileStorage(new \SplFileInfo(__DIR__ . '/../../../metadata/testfiles/100.csv'), new CsvFormat());
     $targetStorage = new DoctrineStorage(self::$em, 'TestEntities\\Address');
     $this->assertEquals(new StorageInfo(['name' => 'SELECT o FROM TestEntities\\Address o', 'count' => 0, 'type' => 'DQL Query']), $targetStorage->info());
     $importer = Importer::build($targetStorage);
     $importConfiguration = new ImportConfiguration();
     $importRun = $importConfiguration->toRun();
     $import = Import::build($importer, $sourceStorage, $importRun);
     $eventDispatcher = new EventDispatcher();
     $importRunner = new ImportRunner(new DefaultWorkflowFactory($eventDispatcher));
     $importRunner->run($import);
     $entities = self::$em->getRepository('TestEntities\\Address')->findAll();
     //import worked
     $this->assertEquals(100, count($entities));
     $exportFile = '/tmp/doctrine_test.csv';
     @unlink($exportFile);
     $sourceStorage = new DoctrineStorage(self::$em, null, self::$em->createQuery("SELECT A FROM TestEntities\\Address A WHERE A.zip LIKE '2%'"));
     $this->assertEquals(new StorageInfo(['name' => "SELECT A FROM TestEntities\\Address A WHERE A.zip LIKE '2%'", 'count' => 10, 'type' => 'DQL Query']), $sourceStorage->info());
     $targetStorage = new LocalFileStorage(new \SplFileInfo($exportFile), new CsvFormat());
     $importer = Importer::build($targetStorage);
     $importConfiguration = new ImportConfiguration();
     $importRun = $importConfiguration->toRun();
     $import = Import::build($importer, $sourceStorage, $importRun);
     $eventDispatcher = new EventDispatcher();
     $importRunner = new ImportRunner(new DefaultWorkflowFactory($eventDispatcher));
     $importRunner->run($import);
     $this->assertFileExists($exportFile);
     $this->assertEquals(11, count(file($exportFile)));
     //+header
     $this->assertEquals(10, $import->getRun()->toArray()['statistics']['processed']);
 }
開發者ID:mathielen,項目名稱:import-engine,代碼行數:35,代碼來源:DoctrineTest.php

示例2: startJobs

 /**
  * {@inheritdoc}
  */
 public function startJobs(ProjectInterface $project)
 {
     $query = 'UPDATE Worldia\\Bundle\\TextmasterBundle\\Entity\\Job j ' . 'SET j.status = :status ' . 'WHERE j.projectId = :projectId ';
     $q = $this->entityManager->createQuery($query)->setParameter('status', JobInterface::STATUS_STARTED)->setParameter('projectId', $project->getId());
     $q->execute();
     $this->entityManager->clear();
 }
開發者ID:worldia,項目名稱:textmaster-bundle,代碼行數:10,代碼來源:JobManager.php

示例3: fillData

 private function fillData()
 {
     self::$data = [];
     $q = $this->entityManager->createQuery("select partial c.{id,name,value} from ItBlaster\\SingleConfigBundle\\Entity\\Config c");
     $res = $q->execute(null, Query::HYDRATE_ARRAY);
     foreach ($res as $k => $v) {
         self::$data[$v['name']] = $v['value'];
     }
 }
開發者ID:it-blaster,項目名稱:single-config-bundle,代碼行數:9,代碼來源:ConfigService.php

示例4: it_performs_a_fulltext_query

 public function it_performs_a_fulltext_query(EntityManagerInterface $entityManager, AbstractQuery $query, $result = [])
 {
     $entityManager->createQuery(Argument::any())->shouldBeCalled()->willReturn($query);
     $query->setParameter(Argument::any(), Argument::any())->shouldBeCalled()->willReturn($query);
     $query->getResult()->shouldBeCalled()->willReturn($result);
     $this->query('black', $entityManager)->shouldBeArray();
 }
開發者ID:ahmadrabie,項目名稱:Sylius,代碼行數:7,代碼來源:OrmFinderSpec.php

示例5: uniqueNameExists

 /**
  * @param $fileName
  * @return bool
  */
 protected function uniqueNameExists($fileName, EntityManagerInterface $em)
 {
     $dql = "SELECT COUNT(image) FROM EDVFileBundle:EdImage AS image WHERE image.hashString = :name";
     $query = $em->createQuery($dql)->setParameters(array('name' => $fileName));
     $result = $query->getSingleScalarResult();
     return $result > 0;
 }
開發者ID:vlatosev,項目名稱:filebundle,代碼行數:11,代碼來源:ImageManager.php

示例6: import

 /**
  * @param Supplier $supplier
  * @param EntityManagerInterface $entityManager
  * @return null
  */
 public function import(Supplier $supplier, EntityManagerInterface $entityManager)
 {
     $params = array('input/webpage/url' => $this->url, '_user' => $this->importIoConfig['user_id'], '_apikey' => $this->importIoConfig['api_key']);
     $result = $this->DataSource->query($this->importIoConfig['connectorGuid'], $params);
     if ($result = json_decode($result)) {
         // delete all supplier products
         $entityManager->createQuery('DELETE ProductBundle:Product p WHERE p.supplier = :supplier')->setParameter('supplier', $supplier)->execute();
         $this->createProducts($entityManager, $supplier, $result);
     }
 }
開發者ID:ernestre,項目名稱:illuminati,代碼行數:15,代碼來源:CiliPicaProductProvider.php

示例7: existsAnyShipmentOption

 public function existsAnyShipmentOption()
 {
     $query = $this->entityManager->createQuery('SELECT 1 FROM ShoPHP\\Shipment\\ShipmentPersonalPoint');
     $query->setMaxResults(1);
     if (count($query->getResult()) > 0) {
         return true;
     }
     $query = $this->entityManager->createQuery('SELECT 1 FROM ShoPHP\\Shipment\\ShipmentCollectionPoint');
     $query->setMaxResults(1);
     if (count($query->getResult()) > 0) {
         return true;
     }
     $query = $this->entityManager->createQuery('SELECT 1 FROM ShoPHP\\Shipment\\ShipmentTransportCompany');
     $query->setMaxResults(1);
     if (count($query->getResult()) > 0) {
         return true;
     }
     return false;
 }
開發者ID:shophp,項目名稱:shophp,代碼行數:19,代碼來源:ShipmentService.php

示例8: clearDb

 protected function clearDb()
 {
     // We can't rely on FK delete cascade as long as we're using sqlite for
     // tests. Doctrine doesn't enable FK support for it.
     $this->em->createQuery('delete from common\\entities\\Outpost')->execute();
     $this->em->createQuery('delete from common\\entities\\CelestialBody')->execute();
     $this->em->createQuery('delete from common\\entities\\System')->execute();
     $this->em->createQuery('delete from common\\entities\\Galaxy')->execute();
     $this->em->createQuery('delete from common\\entities\\CelestialBodyTypeSpecs')->execute();
     $this->em->createQuery('delete from common\\entities\\Universe')->execute();
     $this->em->createQuery('delete from common\\entities\\User')->execute();
     $this->em->flush();
 }
開發者ID:iw-reload,項目名稱:iw,代碼行數:13,代碼來源:TestCase.php

示例9: getQuery

 /**
  * Constructs a Query instance from the current specifications of the builder.
  *
  * <code>
  *     $qb = $em->createQueryBuilder()
  *         ->select('u')
  *         ->from('User', 'u');
  *     $q = $qb->getQuery();
  *     $results = $q->execute();
  * </code>
  *
  * @return Query
  */
 public function getQuery()
 {
     $parameters = clone $this->parameters;
     $query = $this->_em->createQuery($this->getDQL())->setParameters($parameters)->setFirstResult($this->_firstResult)->setMaxResults($this->_maxResults);
     if ($this->lifetime) {
         $query->setLifetime($this->lifetime);
     }
     if ($this->cacheMode) {
         $query->setCacheMode($this->cacheMode);
     }
     if ($this->cacheable) {
         $query->setCacheable($this->cacheable);
     }
     if ($this->cacheRegion) {
         $query->setCacheRegion($this->cacheRegion);
     }
     return $query;
 }
開發者ID:Dren-x,項目名稱:mobitnew,代碼行數:31,代碼來源:QueryBuilder.php

示例10: getAll

 /**
  * @return Order[]|\Traversable
  */
 public function getAll($limit, $offset)
 {
     $query = $this->entityManager->createQuery(sprintf('SELECT o FROM %s o', Order::class));
     $query->setFirstResult($offset)->setMaxResults($limit);
     return new Paginator($query);
 }
開發者ID:shophp,項目名稱:shophp,代碼行數:9,代碼來源:OrderService.php

示例11: __invoke

 public function __invoke()
 {
     $query = $this->em->createQuery('SELECT b.title, COUNT(a) as authorsCount FROM AppBundle:Book b LEFT JOIN AppBundle:Author a WITH b MEMBER OF a.books');
     return $query->getResult();
 }
開發者ID:Gorik,項目名稱:Doctrine2-Relations,代碼行數:5,代碼來源:BooksWithAuthorsCount.php

示例12: createQuery

 /**
  * {@inheritdoc}
  */
 public function createQuery($dql = '')
 {
     return $this->wrapped->createQuery($dql);
 }
開發者ID:Dren-x,項目名稱:mobitnew,代碼行數:7,代碼來源:EntityManagerDecorator.php

示例13: queryEntity

 private function queryEntity(EntityManagerInterface $em, $label)
 {
     $times = 100;
     $size = 500;
     $startPersist = microtime(true);
     echo PHP_EOL . $label;
     for ($i = 0; $i < $size; $i++) {
         $em->persist(new Country("Country {$i}"));
     }
     $em->flush();
     $em->clear();
     printf("\n[%s] persist %s countries", number_format(microtime(true) - $startPersist, 6), $size);
     $dql = 'SELECT c FROM Doctrine\\Tests\\Models\\Cache\\Country c WHERE c.name LIKE :name';
     $startFind = microtime(true);
     for ($i = 0; $i < $times; $i++) {
         $em->createQuery($dql)->setParameter('name', "%Country%")->setCacheable(true)->getResult();
     }
     printf("\n[%s] select %s countries (%s times)", number_format(microtime(true) - $startFind, 6), $size, $times);
     printf("\n%s\n", str_repeat('-', 50));
 }
開發者ID:selimcr,項目名稱:servigases,代碼行數:20,代碼來源:SecondLevelCacheTest.php

示例14: count

 /**
  * @return  Integer
  */
 public function count()
 {
     return $this->entityManager->createQuery("SELECT COUNT('e') FROM " . $this->getEntity() . " e")->getSingleScalarResult();
 }
開發者ID:mkbrv,項目名稱:laravel-doctrine-project,代碼行數:7,代碼來源:AbstractRepository.php

示例15: getResultsCount

 /**
  * Gets total results count.
  *
  * @param array $query
  *
  * @return int
  */
 private function getResultsCount($query)
 {
     $queryObject = $this->entityManager->createQuery(str_replace('SELECT ' . $this->select, 'SELECT COUNT(p.id) cnt', $query['query']));
     $queryObject->setParameters($query['parameters']);
     return $queryObject->getSingleScalarResult();
 }
開發者ID:mvar,項目名稱:filtered-list-bundle,代碼行數:13,代碼來源:ListManager.php


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