我想知道我的表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)
感谢。
答案 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();
}