存储库中的symfony if函数
我正在尝试在存储库中执行此函数存储库中的symfony if函数,symfony,doctrine,Symfony,Doctrine,我正在尝试在存储库中执行此函数 public function getInfoAsManagers() { $q = $this->createQueryBuilder('user'); $q->select(['user.id', 'user.firstName', 'user.lastName', 'position.name', 'IF(COUNT(mpkManager.user)>0, 1, 0) as isManager']); $q->
public function getInfoAsManagers()
{
$q = $this->createQueryBuilder('user');
$q->select(['user.id', 'user.firstName', 'user.lastName', 'position.name', 'IF(COUNT(mpkManager.user)>0, 1, 0) as isManager']);
$q->leftJoin('user.position', 'position', 'WITH', 'user.position=position');
$q->leftJoin('PCK\ExtraBundle\Entity\MpkManager', 'mpkManager', 'WITH', 'mpkManager.user=user');
$q->groupBy('user');
return $q->getQuery()->getResult();
}
但我已经上了荧幕
[语法错误]第0行,第62列:错误:应为已知函数,得到'IF'
如何在自定义查询中使用IF函数
我可以用这样的东西吗
$q->addSelect(DB::raw('PURE SQL'));
只需添加createNativeQuery()
或
案例
ELSE添加IF函数
$em = $this->getDoctrine()->getEntityManager();
$qb = $em->createQueryBuilder();
$q = $qb
->select("c.id")
->addSelect("CASE WHEN (c.parent IS NULL) THEN c.name ELSE 'something' END")
->from("MyBundle:Category", "c")
->leftJoin("c.parent", "t");
echo $q->getQuery()->getSQL();