通的条件阵列教义EXPR() - > ORX()方法(pass array of condit

2019-06-26 14:20发布

我需要构建DQL与QueryBuilder这样

[QUERY]... AND WHERE e.type = x OR e.type = Y OR e.type = N [...]

我有类型的数组如何传递这个数组我的查询生成器?

$qb->andWhere($qb->expr()->orx(CONDITIONS));

类型列表将是动态的,调用$qb->andWhere每个类型的foreach循环将只有更哪来没有更多的OR值。
我可以将成倍orx表达式,然后将其添加到andWhere ? 任何想法如何解决这个问题,很可能,常见的问题?

Answer 1:

我希望如此,后来我发现这一点:

$conditions = array('e.type = x', 'e.type = Y', 'e.type = N');
$orX = $qb->expr()->orX();

foreach ($conditions as $condition) {
    $orX->add($condition);
}

$qb->add('where', $orX);

使用@meze建议,你可以简化代码,取而代之的foreach语句:

$orX->addMultiple($conditions);


Answer 2:

@DEY他的回答可以简化。 无需对foreach,这也适用:

$conditions = array('e.type = x', 'e.type = Y', 'e.type = N');

$orX = $qb->expr()->orX();
$orX->addMultiple($conditions);

$qb->where($orX);


Answer 3:

我知道tommarow会是一个更好的日子。 解决方法很简单。 你可以让数组或表达式,像这样

$ors[] = $qb->expr()->orx('e.type = '.$qb->expr()->literal($value));

然后只需将其添加到andWhere()/凡通过查询生成器()方法连接方法如下所示:

$qb->andWhere(join(' OR ', $ors));


Answer 4:

您还可以使用...像PHP:

$conditions = array('e.type = x', 'e.type = Y', 'e.type = N');
$criteria = Criteria::create();
$criteria->andWhere(Criteria::expr()->orX(...$conditions));


Answer 5:

您也可以使用call_user_func_array功能这样 。

它可以让你调用传递一个数组的项目作为参数的方法。



文章来源: pass array of conditions to doctrine expr()->orx() method