在SF2 queryBuilder中的AND子句中添加OR子句

时间:2015-04-12 19:14:32

标签: php sql symfony query-builder

我想在SF2查询构建器中执行类似的请求:

SELECT *
FROM `annonce` a 
LEFT JOIN `ville` v ON a.ville_id=v.id 
WHERE a.titre LIKE '%s%' AND (v.cp LIKE '94%' OR v.nomComplet='alf%')

但我不知道如何在AND子句中包含OR子句。目前我有:

$qb = $this->createQueryBuilder('a')
                ->select('a')
                ->leftJoin('a.ville', 'v');
        $qb->where($qb->expr()->like('a.titre', ':titre'))
                ->andWhere($qb->expr()->like('v.cp', ':lieu'))
                ->OrWhere($qb->expr()->like('v.nomComplet', ':lieu'))
                ->setParameter('titre', '%' . $item . '%')
                ->setParameter('lieu', $lieu . '%')
                ->getQuery()
                ->getResult();

但这不是正确的实施。我需要在AndWhere中使用OrWhere

感谢您的帮助

1 个答案:

答案 0 :(得分:0)

您正在寻找的是orX condition

$qb->expr()->andWhere(
    $qb->expr()->orX(
        $qb->expr()->like('v.cp', ':lieu'),
        $qb->expr()->like('v.nomComplet', ':lieu')
    )
)