使用 createQuery 的 Doctrine 查询返回结果数

问题描述 投票:0回答:2
$q = $this->_em->createQuery("SELECT s FROM app\models\Quest s 
                                    LEFT JOIN s.que c
                                    WHERE s.type = '$sub'
                                    AND c.id = '$id'");

给定一个像上面这样的查询,我将如何检索结果的数量?

php doctrine-orm
2个回答
1
投票

或者,您可以查看 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
投票

您可以预先执行计数查询:

$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);

如果您需要计数,请使用第一种方法,以便您可以在实际检索对象之前做出决定。

© www.soinside.com 2019 - 2024. All rights reserved.