Возвращает количество результатов запроса Doctrine, использующего createQuery. - PullRequest
0 голосов
/ 13 декабря 2011
$q = $this->_em->createQuery("SELECT s FROM app\models\Quest s 
                                    LEFT JOIN s.que c
                                    WHERE s.type = '$sub'
                                    AND c.id = '$id'");

С учетом запроса, подобного приведенному выше, как мне получить количество результатов?

Ответы [ 2 ]

1 голос
/ 10 сентября 2013

В качестве альтернативы можно посмотреть, что класс Doctrine Paginator делает с объектом Query, чтобы получить счет (хотя этот подход, скорее всего, является излишним, но он отвечает на ваш вопрос):

public function count()
{
if ($this->count === null) {
    /* @var $countQuery Query */
    $countQuery = $this->cloneQuery($this->query);

    if ( ! $countQuery->getHint(CountWalker::HINT_DISTINCT)) {
        $countQuery->setHint(CountWalker::HINT_DISTINCT, true);
    }

    if ($this->useOutputWalker($countQuery)) {
        $platform = $countQuery->getEntityManager()->getConnection()->getDatabasePlatform(); // law of demeter win

        $rsm = new ResultSetMapping();
        $rsm->addScalarResult($platform->getSQLResultCasing('dctrn_count'), 'count');

        $countQuery->setHint(Query::HINT_CUSTOM_OUTPUT_WALKER, 'Doctrine\ORM\Tools\Pagination\CountOutputWalker');
        $countQuery->setResultSetMapping($rsm);
    } else {
        $countQuery->setHint(Query::HINT_CUSTOM_TREE_WALKERS, array('Doctrine\ORM\Tools\Pagination\CountWalker'));
    }

    $countQuery->setFirstResult(null)->setMaxResults(null);

    try {
        $data =  $countQuery->getScalarResult();
        $data = array_map('current', $data);
        $this->count = array_sum($data);
    } catch(NoResultException $e) {
        $this->count = 0;
    }
}
return $this->count;
}
0 голосов
/ 19 января 2012

Вы можете выполнить запрос подсчета заранее:

$count = $em->createQuery('SELECT count(s) FROM app\models\Quest s 
                                    LEFT JOIN s.que c
                                    WHERE s.type=:type
                                    AND c.id=:id)
                 ->setParameter('type', $sub);
                 ->setParameter('id', $id);
                 ->getSingleScalarResult();

Или просто выполнить запрос и получить размер массива результатов:

$quests = $q->getResult();
$count = count($quests);

Использовать первый методесли вам нужен подсчет, чтобы вы могли принять решение до фактического извлечения объектов.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...