Symfony2:来自querybuilder的计数

时间:2014-12-17 18:29:29

标签: symfony doctrine

我想知道我的表TABLE中的行数以及属性名称=“joe”

这里是我到目前为止使用的代码,但我检索了对象(这是不必要的,所以没有优化)

$repository = $this->getDoctrine()->getManager()->getRepository('MyBundle:TABLE');
$name = "joe";
$liste = $repository->findBy(array('name' => $name));
$nombre = count($liste);

如何使用countbuilder使用count实现它?需要设置参数$ name。到目前为止我所看到的都没有参数like this one,所以不知道它是如何工作的......(而且我想避免使用paginator)

感谢。

1 个答案:

答案 0 :(得分:8)

你可以这样做:

$repository = $this->getDoctrine()->getManager()->getRepository('MyBundle:TABLE');
$name = "joe";
$qb = $repository->createQueryBuilder('t');
$qb->select('count(t.id)');
$qb->where('t.name = :name');
$qb->setParameter('name', $name);
$nombre = $qb->getQuery()->getSingleScalarResult();

但良好的做法是将此逻辑放入存储库类,因此您可以调用这样的方法:

$nombre = $repository->countByName($name); 

只需在TableRepository类中创建新方法:

public function countByName($name)
{
    $qb = $this->createQueryBuilder('t');
    $qb->select('count(t.id)');
    $qb->where('t.name = :name');
    $qb->setParameter('name', $name);

    return $qb->getQuery()->getSingleScalarResult();
}