doctrine2 - querybuilder, empty parameters

本小妞迷上赌 提交于 2019-12-04 15:16:50

The query builder is exactly there for building conditional queries. You could do:

$qb = $this->_em->createQueryBuilder();

$query = $qb->select('u')
            ->from('Users', 'u')
            ->where('u.id = ?1')                   
            ->setParameter(1, $userid);

if ($status) {
    $qb->andWhere('u.status = ?2')
       ->setParameter(2, $status);
}

return $qb->getQuery()->getResult();

On a side note, it is best practice to use named placeholders e. g. like this:

    $qb->andWhere('u.status = :status')
       ->setParameter('status', $status);

You could write:

->andWhere('(u.status= ?2 or ?2 is null)')
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!