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


PHP EntityManager::createQueryBuilder方法代碼示例

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


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

示例1: createQueryBuilder

 /**
  * @param string|null
  * @param string|null
  * @param string|null
  * @return QueryBuilder
  */
 public function createQueryBuilder($entityClass = NULL, $alias = NULL, $indexBy = NULL)
 {
     $qb = $this->entityManager->createQueryBuilder();
     if ($entityClass) {
         $qb->from($entityClass, $alias, $indexBy);
         $qb->select($alias);
     }
     return $qb;
 }
開發者ID:librette,項目名稱:doctrine-queries,代碼行數:15,代碼來源:Queryable.php

示例2: delete

 public function delete($value)
 {
     // formating hours on date
     $date = new \DateTime(strtotime(time()));
     $date = $date->modify('-' . $value . 'hours')->format('Y-m-d H:i:s');
     // deleting rows by doctrine with cascade delete entity settings in db schema
     $qb = $this->em->createQueryBuilder();
     $q = $qb->delete(Search::getClassName(), 's')->where($qb->expr()->lt('s.date', '?1'))->setParameter(1, $date)->getQuery();
     return $numberDeleted = $q->getResult();
 }
開發者ID:tkliner,項目名稱:etn-github,代碼行數:10,代碼來源:TimeDelete.php

示例3: getNextPositionByEvent

 /**
  * @param \App\Model\Event\Entity\Event $event
  *
  * @return array
  */
 public function getNextPositionByEvent(Entity\Event $event)
 {
     $query = $this->em->createQueryBuilder()->select('MAX(p.position)')->from(Entity\Performance::class, 'p')->whereCriteria(['p.event' => $event])->getQuery();
     try {
         $result = $query->getResult(AbstractQuery::HYDRATE_SINGLE_SCALAR);
         $nextPosition = $result + 1;
     } catch (NoResultException $e) {
         $nextPosition = 1;
     }
     return $nextPosition;
 }
開發者ID:Kotys,項目名稱:eventor.io,代碼行數:16,代碼來源:Performance.php

示例4: generateAndPersistNewAddresses

 private function generateAndPersistNewAddresses(int $count)
 {
     $qb = $this->entityManager->createQueryBuilder();
     $qb->select('MAX(address.bip32index)')->from(Address::getClassName(), 'address');
     $index = (int) $qb->getQuery()->getSingleScalarResult();
     for ($i = 0; $i < $count; $i++) {
         list($address, $index) = $this->generateNewAddress($index);
         $addressEntity = new Address($address, $index);
         $this->entityManager->persist($addressEntity);
     }
     $this->entityManager->flush();
     file_put_contents($this->newAddressesFile, true);
 }
開發者ID:ParalelniPolis,項目名稱:bitcoinJukebox,代碼行數:13,代碼來源:AddressProvider.php

示例5: getInvitation

 /**
  * @param string $email
  * @param string|null $token
  * @return Invitation|null
  */
 public function getInvitation($email, $token = null)
 {
     $qb = $this->em->createQueryBuilder();
     $qb->select('i, partial s.{id, username}')->from(Invitation::class, 'i')->leftJoin('i.sender', 's')->where('i.email = :email')->setParameter('email', $email);
     if (isset($token)) {
         $qb->andWhere('i.token = :token')->setParameter('token', $token);
     }
     try {
         $invitation = $qb->getQuery()->getSingleResult();
     } catch (NoResultException $e) {
         $this->onInfo("Email: {$email} NOT found. [getInvitationByEmail]", $e, self::class);
         return null;
     }
     return $invitation;
 }
開發者ID:blitzik,項目名稱:vycetky-doctrine,代碼行數:20,代碼來源:InvitationsReader.php

示例6: createBasicQuery

 private function createBasicQuery(Kdyby\Doctrine\EntityManager $entityManager)
 {
     $qb = $entityManager->createQueryBuilder();
     $qb->from(Comment::class, 'c');
     foreach ($this->filter as $modifier) {
         $modifier($qb);
     }
     return $qb;
 }
開發者ID:blitzik,項目名稱:CMS,代碼行數:9,代碼來源:CommentQuery.php

示例7: getBasicDQL

 /**
  * @param int $listingID
  * @return \Kdyby\Doctrine\QueryBuilder
  */
 private function getBasicDQL($listingID = null)
 {
     $qb = $this->em->createQueryBuilder();
     $qb->select('li, lo, wh')->from(ListingItem::class, 'li')->innerJoin('li.listing', 'l')->innerJoin('li.locality', 'lo')->innerJoin('li.workedHours', 'wh');
     if (isset($listingID)) {
         $qb->where('li.listing = :listingID')->setParameter('listingID', $listingID);
     }
     return $qb;
 }
開發者ID:blitzik,項目名稱:vycetky-doctrine,代碼行數:13,代碼來源:ListingItemsReader.php

示例8: getEventsByUser

 /**
  * Získá události pro konkrétního uživatele
  * @param \App\Model\Entity\User $user
  * @return type
  */
 function getEventsByUser($userEntity)
 {
     if ($userEntity) {
         /** @var \App\Model\Entity\Client $client */
         $client = $userEntity->getClient();
         $qb = $this->em->createQueryBuilder();
         $qb->from('\\App\\Model\\Entity\\Event', 'e')->join('\\App\\Model\\Entity\\User', 'u')->select('e')->where($qb->expr()->andX($qb->expr()->orX($qb->expr()->isNull('e.deletedAt'), $qb->expr()->gt('e.deletedAt', ':now')), $qb->expr()->eq('e.client', $client->id)))->setParameter('now', new \DateTime('now'));
         return $qb->getQuery()->getResult();
     }
     return array();
 }
開發者ID:MrTommy1979,項目名稱:reference,代碼行數:16,代碼來源:EventService.php

示例9: getPage

 /**
  * @param int $pageID
  * @param bool $withCommentsCount
  * @return Page|null
  */
 public function getPage($pageID, $withCommentsCount = false)
 {
     $pageQB = $this->em->createQueryBuilder();
     $pageQB->select('p, u, l')->from(Page::class, 'p')->join('p.url', 'u')->join('p.locale', 'l')->where('p.id = :pageID')->setParameter('pageID', $pageID);
     if ((bool) $withCommentsCount === true) {
         $pageQB->addSelect('COUNT(c.page) AS commentsCount');
         $pageQB->leftJoin(Comment::class, 'c', Join::WITH, 'c.page = p');
         $pageQB->groupBy('p.id');
     }
     $page = $pageQB->getQuery()->getOneOrNullResult();
     return $page;
 }
開發者ID:blitzik,項目名稱:CMS,代碼行數:17,代碼來源:PageFacade.php

示例10: getUrlEntity

 /**
  * @param $presenter
  * @param $action
  * @param $internal_id
  * @return Url
  */
 private function getUrlEntity($presenter, $action, $internal_id = null)
 {
     $qb = $this->em->createQueryBuilder();
     $qb->select('u, rt')->from(Url::class, 'u')->leftJoin('u.actualUrlToRedirect', 'rt')->where('u.presenter = :p AND u.action = :a')->setParameters(['p' => $presenter, 'a' => $action]);
     if ($internal_id !== null) {
         $qb->andWhere('u.internalId = :i')->setParameter('i', $internal_id);
     }
     $url = $qb->getQuery()->setMaxResults(1)->getResult();
     if (empty($url)) {
         return null;
     }
     return $url[0];
 }
開發者ID:blitzik,項目名稱:CMS,代碼行數:19,代碼來源:Router.php

示例11: isValueDuplicate

 /**
  * @param  EntityManager    $em
  * @param  string           $entity
  * @param  string           $attribute
  * @param  string           $value
  * @param  string           $locale
  * @return BaseEntity|FALSE if value if not a duplicate
  */
 public function isValueDuplicate(EntityManager $em, $entity, $attribute, $value, $locale = null)
 {
     $qb = $em->createQueryBuilder();
     $qb->select('e')->from($entity, 'e');
     if (empty($locale)) {
         $qb->where('e.' . $attribute . ' = :' . $attribute);
         $qb->setParameter($attribute, $value);
     } else {
         $qb->leftJoin('e.translations', 't');
         $qb->where('t.' . $attribute . ' = :' . $attribute . ' AND t.locale = :locale');
         $qb->setParameters([$attribute => $value, 'locale' => $locale]);
     }
     $result = $qb->getQuery()->getResult();
     return !empty($result) ? $result[0] : false;
 }
開發者ID:CSHH,項目名稱:website,代碼行數:23,代碼來源:DuplicityChecker.php

示例12: getMostReadedArticles

 /**
  * Vraci nejctenejsi clanky
  * @param int $count
  * @param DateTime|NULL $period
  * @return Entities\Article[]
  */
 public function getMostReadedArticles($count = 1, $period = NULL)
 {
     if ($period === NULL) {
         $now = new DateTime();
         $period = $now->modify("-2 month");
     }
     $cacheId = 'read-' . $count;
     $query = $this->em->createQueryBuilder();
     //vyhledavaci podminka
     $whereConditon = $query->expr()->andX();
     $whereConditon->add($query->expr()->gt('a.publishDate', ':period'));
     $whereConditon->add($query->expr()->eq('a.published', 'TRUE'));
     $result = $query->select('a')->from('App\\Model\\Entities\\Article', 'a')->where($whereConditon)->orderBy('a.counter', 'DESC')->setMaxResults($count)->getQuery()->useResultCache(TRUE, 600, $cacheId);
     $result->setParameter('period', $period);
     return $result->getResult();
 }
開發者ID:krupaj,項目名稱:my-blog,代碼行數:22,代碼來源:ArticleRepository.php

示例13: getBasicDQL

 private function getBasicDQL($id)
 {
     $qb = $this->em->createQueryBuilder();
     $qb->select('l')->from(Listing::class, 'l')->where('l.id = :id')->setParameter('id', $id);
     return $qb;
 }
開發者ID:blitzik,項目名稱:vycetky-doctrine,代碼行數:6,代碼來源:ListingsReader.php

示例14: getAllGenreNames

 /**
  * @return string[]
  */
 public function getAllGenreNames() : array
 {
     $qb = $this->entityManager->createQueryBuilder();
     $qb->select('g.name')->from(Genre::getClassName(), 'g');
     return array_column($qb->getQuery()->getScalarResult(), 'name');
 }
開發者ID:ParalelniPolis,項目名稱:bitcoinJukebox,代碼行數:9,代碼來源:GenresManager.php

示例15: findContentEntity

 /**
  * @param $namespace
  * @param $name
  * @param $locale
  * @return DoctrineEntity
  */
 private function findContentEntity($namespace, $name, $locale)
 {
     /** @var DoctrineEntity[] $result */
     return $this->entityManager->createQueryBuilder()->select('c')->from(DoctrineEntity::class, 'c')->where('c.namespace = :namespace')->andWhere('c.name = :name')->andWhere('c.locale = :locale')->setParameters(['namespace' => $namespace, 'name' => $name, 'locale' => $locale])->getQuery()->getOneOrNullResult();
 }
開發者ID:FreezyBee,項目名稱:Editrouble,代碼行數:11,代碼來源:Doctrine.php


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