コード例 #1
0
 /**
  * @param Kdyby\Persistence\Queryable|Kdyby\Doctrine\EntityDao $repository
  * @return Kdyby\Doctrine\NativeQueryBuilder
  */
 private function createBasicDql(Kdyby\Persistence\Queryable $repository)
 {
     $qb = (new QueryBuilder($repository->getEntityManager()))->select('partial l.{id, description, year, month}')->from(Listing::class, 'l')->leftJoin(ListingItem::class, 'li WITH li.listing = l')->leftJoin('li.workedHours', 'wh');
     foreach ($this->filter as $modifier) {
         $modifier($qb);
     }
     return $qb;
 }
コード例 #2
0
ファイル: Query.php プロジェクト: zaxxx/zaxcms
 protected function doCreateQuery(Kdyby\Persistence\Queryable $repository)
 {
     $qb = $repository->createQueryBuilder()->select('a, b, c, d')->from(Model\CMS\Entity\Article::getClassName(), 'a')->leftJoin('a.category', 'b')->leftJoin('a.tags', 'c')->leftJoin('a.authors', 'd');
     $this->applyFilters($qb);
     $qb->addOrderBy('a.createdAt', 'DESC');
     $query = $qb->getQuery()->useResultCache(TRUE, NULL, Model\CMS\Service\ArticleService::CACHE_TAG);
     return $query;
 }
コード例 #3
0
 /**
  * @param Queryable $repository
  * @return QueryBuilder
  */
 protected function doCreateQuery(Queryable $repository)
 {
     $queryBuilder = $repository->createQueryBuilder()->select('s')->from(ScopeEntity::class, 's');
     foreach ($this->filters as $filter) {
         $filter($queryBuilder);
     }
     return $queryBuilder;
 }
コード例 #4
0
 /**
  * @param Kdyby\Persistence\Queryable|Kdyby\Doctrine\EntityDao $repository
  * @return Kdyby\Doctrine\NativeQueryBuilder
  */
 private function createBasicDql(Kdyby\Persistence\Queryable $repository)
 {
     $this->queryBuilder = (new QueryBuilder($repository->getEntityManager()))->select('i')->from(Invitation::class, 'i');
     foreach ($this->filter as $modifier) {
         $modifier($this->queryBuilder);
     }
     return $this->queryBuilder;
 }
コード例 #5
0
ファイル: SearchQuery.php プロジェクト: tkliner/etn-github
 /**
  * @param Queryable|Kdyby\Doctrine\EntityDao $repository
  * @return NativeQueryBuilder
  */
 private function createBasicDql(Queryable $repository)
 {
     $qb = $repository->createQueryBuilder('Search');
     foreach ($this->filter as $modifier) {
         $modifier($qb);
     }
     return $qb;
 }
コード例 #6
0
ファイル: CommentQuery.php プロジェクト: blitzik/CMS
 protected function doCreateQuery(Kdyby\Persistence\Queryable $repository)
 {
     $qb = $this->createBasicQuery($repository->getEntityManager());
     $qb->select('c')->orderBy('c.id');
     foreach ($this->select as $modifier) {
         $modifier($qb);
     }
     return $qb;
 }
コード例 #7
0
ファイル: Query.php プロジェクト: zaxxx/zaxcms
 protected function doCreateQuery(Kdyby\Persistence\Queryable $repository)
 {
     $qb = $repository->createQueryBuilder()->select('a.slug, a.firstName, a.surname, a.perex, a.image, COUNT(b) AS countArticles')->from(Model\CMS\Entity\Author::getClassName(), 'a')->leftJoin('a.articles', 'b')->groupBy('a.id')->addOrderBy('a.surname', 'ASC');
     //->addOrderBy('countArticles', 'DESC')
     //->addOrderBy('a.id', 'DESC');
     $this->applyFilters($qb);
     $query = $qb->getQuery()->useResultCache(TRUE, NULL, Model\CMS\Service\ArticleService::CACHE_TAG);
     return $query;
 }
コード例 #8
0
ファイル: AccessDefinitionQuery.php プロジェクト: blitzik/CMS
 protected function doCreateQuery(Kdyby\Persistence\Queryable $repository)
 {
     $qb = $this->createBasicQuery($repository->getEntityManager());
     $qb->innerJoin('a.resource', 'r')->innerJoin('a.privilege', 'p')->select('a, r, p')->orderBy('a.resource');
     foreach ($this->select as $modifier) {
         $modifier($qb);
     }
     return $qb;
 }
コード例 #9
0
ファイル: Query.php プロジェクト: zaxxx/zaxcms
 protected function doCreateQuery(Kdyby\Persistence\Queryable $repository)
 {
     $qb = $repository->createQueryBuilder()->select('perm', 'res', 'priv')->from(Model\CMS\Entity\Permission::getClassName(), 'perm')->join('perm.resource', 'res')->join('perm.privilege', 'priv')->orderBy('res.id, priv.id');
     $this->applyFilters($qb);
     $query = $qb->getQuery()->useResultCache(TRUE, NULL, Model\CMS\AclFactory::CACHE_TAG);
     $query->setHint(Doctrine\ORM\Query::HINT_CUSTOM_OUTPUT_WALKER, 'Gedmo\\Translatable\\Query\\TreeWalker\\TranslationWalker');
     $query->setHint(Gedmo\Translatable\TranslatableListener::HINT_TRANSLATABLE_LOCALE, $this->locale);
     return $query;
 }
コード例 #10
0
ファイル: ImageQuery.php プロジェクト: blitzik/CMS
 /**
  * @param \Kdyby\Persistence\Queryable $repository
  * @return \Doctrine\ORM\Query|\Doctrine\ORM\QueryBuilder
  */
 protected function doCreateQuery(Kdyby\Persistence\Queryable $repository)
 {
     $qb = $this->getBasicDQL($repository->getEntityManager());
     $qb->select('i');
     $qb->addOrderBy('i.uploadedAt', 'DESC');
     foreach ($this->select as $modifier) {
         $modifier($qb);
     }
     return $qb;
 }
コード例 #11
0
 /**
  * @param \Kdyby\Persistence\Queryable $repository
  * @return \Doctrine\ORM\Query|\Doctrine\ORM\QueryBuilder
  */
 protected function doCreateQuery(Queryable $repository)
 {
     $qb = $repository->createQueryBuilder()->select('a')->from('App\\Entity', 'a');
     if ($this->_doCreateQuery) {
         call_user_func($this->_doCreateQuery, $qb);
     } else {
         $this->applyAllFilters($qb);
     }
     return $qb;
 }
コード例 #12
0
ファイル: Query.php プロジェクト: zaxxx/zaxcms
 protected function doCreateQuery(Kdyby\Persistence\Queryable $repository)
 {
     $qb = $repository->createQueryBuilder()->select('a, b, c')->from(Model\CMS\Entity\User::getClassName(), 'a')->join('a.role', 'b')->join('a.login', 'c');
     $this->applyFilters($qb);
     $query = $qb->getQuery()->useResultCache(TRUE, NULL, Model\CMS\AclFactory::CACHE_TAG);
     if ($this->locale !== NULL) {
         $query->setHint(Gedmo\Translatable\TranslatableListener::HINT_TRANSLATABLE_LOCALE, $this->locale);
     }
     return $query;
 }
コード例 #13
0
ファイル: Query.php プロジェクト: zaxxx/zaxcms
 protected function doCreateQuery(Kdyby\Persistence\Queryable $repository)
 {
     $qb = $repository->createQueryBuilder()->select('a')->from(Model\CMS\Entity\Page::getClassName(), 'a');
     $this->applyFilters($qb);
     return $qb->getQuery()->useResultCache(TRUE, NULL, Model\CMS\Service\PageService::CACHE_TAG);
 }
コード例 #14
0
 /** @inherit */
 protected function doCreateQuery(Kdyby\Persistence\Queryable $repository)
 {
     return $repository->select('user')->where('name = :nameOrEmail OR email = :nameOrEmail')->setParameter('nameOrEmail', $this->nameOrEmail);
 }
コード例 #15
0
 /**
  * @param Queryable $repository
  * @return QueryBuilder
  */
 protected function doCreateQuery(Queryable $repository)
 {
     return $repository->createQueryBuilder('screenplay')->select('partial screenplay.{id}')->innerJoin('screenplay.episode', 'episode')->innerJoin('episode.season', 'season')->andWhere('season.language = :language')->setParameter('language', $this->language)->andWhere('screenplay.character IS NOT NULL');
 }
コード例 #16
0
 /**
  * @param Kdyby\Persistence\Queryable|Kdyby\Doctrine\EntityDao $repository
  * @return Kdyby\Doctrine\NativeQueryBuilder
  */
 private function createBasicDql(Kdyby\Persistence\Queryable $repository)
 {
     $this->queryBuilder = (new QueryBuilder($repository->getEntityManager()))->select('sm')->from(SentMessage::class, 'sm')->orderBy('sm.id', 'DESC');
     foreach ($this->filter as $modifier) {
         $modifier($this->queryBuilder);
     }
     return $this->queryBuilder;
 }