передайте массив условий методу doctrine expr()->orx()


Мне нужно построить DQL с QueryBuilder таким образом

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

У меня есть типы в массиве, как я могу передать этот массив в мой конструктор запросов?

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

Список типов будет динамическим, вызов $qb->andWhere в каждом цикле типов для каждого типа будет только больше, И ГДЕ больше не будет OR.
Могу ли я сохранить выражения multiply orx, а затем добавить их в andWhere? Есть идеи, как решить эту, вероятно, распространенную проблему?

Author: Wilt, 2012-07-29

5 answers

Я надеюсь на это, тогда я нашел это:

$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);
 54
Author: DEY, 2016-07-06 12:05:15

@ДЕЙ его ответ можно упростить. Нет необходимости в foreach, это также работает:

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

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

$qb->where($orX);
 7
Author: Wilt, 2015-10-20 17:16:53

Я знал, что в томмароу будет лучший день. Решение очень простое. Вы можете создать массив выражений ИЛИ, например, так

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

А затем просто добавьте его в метод andWhere()/Where() построителя запросов с помощью метода соединения, например:

$qb->andWhere(join(' OR ', $ors));
 6
Author: Bartosz Rychlicki, 2012-07-29 11:36:18

Вы также можете использовать функцию call_user_func_array следующим образом.

Он позволяет вызывать метод, передающий элементы массива в качестве параметров.

 1
Author: Jens, 2017-05-23 12:02:46

Вы также можете использовать ... в php, например:

$conditions = array('e.type = x', 'e.type = Y', 'e.type = N');
$criteria = Criteria::create();
$criteria->andWhere(Criteria::expr()->orX(...$conditions));
 1
Author: Karol Gasienica, 2018-01-26 08:55:36