Вопрос по php – Doctrine 2 DQL - Выберите строки, в которых поле «многие ко многим» пусто?

19

У меня есть два класса в этом примере - DeliveryMethod и Country. У них много-много-много отношений друг с другом.

Что я хочу сделать, это выбрать все методы доставки, для которых не назначены страны.

Я могу сделать наоборот, то есть выбрать все способы доставки, которые имеют хотя бы одну страну -

<code>SELECT m FROM DeliveryMethod m JOIN m.countries
</code>

Но я не могу понять, как сделать выбор, где поле стран пустое. В простом SQL я бы сделал следующее (deliverymethod_country - таблица ссылок):

<code>SELECT m.* FROM deliverymethods m
LEFT JOIN deliverymethod_country dc ON dc.deliverymethod_id = m.id
WHERE dc.deliverymethod_id IS NULL
</code>

Однако любой DQL-эквивалент этого не работает, например:

<code>SELECT m FROM DeliveryMethod m LEFT JOIN m.countries WHERE m.countries IS NULL
</code>

Что дает мне эту ошибку:

<code>[Syntax Error] line 0, col 75: Error: Expected end of string, got 'm'
</code>

Ваш Ответ

4   ответа
45
Use Doctrine's is empty

$qb->select('m')->from('DeliveryMethods', 'm')->where('m.countries is empty')

Увидеть:Doctrine 2 ORM Документация: Doctrine Query Language (поиск по запросу "пусто")

Лучший ответ. Я ищу способ использовать это вExpr контекст, см.stackoverflow.com/questions/41935897/…
Это должен быть главный ответ.
@spackmat Спасибо, и готово ;-)
14

SIZE функция:

$qb->select('m')
   ->from('DeliveryMethods','m')
   ->where('SIZE(m.countries) = 0');

Это даст вам все методы без привязки стран

в лучшем ответе исключаются исключения, в которых вам может понадобиться другой запрос из-за "наличия". Доктрина определит лучшую стратегию, например, она выполнит выборку, если отношение не извлечено.
0

IIRC. Извинения за опечатку в твиттере должны были сказать "не могу".

15

$qb ваш экземпляр построителя запросов

$qb->select('m')
   ->from('DeliveryMethods','m')
   ->leftJoin('m.countries','c')
   ->having('COUNT(c.id) = 0')
   ->groupBy('m.id');

Это даст вам DeliveryMethods, который связан со странами, и количество связанных стран равно 0

@parisssss Я думаю, то же самое должно работать и в One-To-One. Если подумать, если левая сущность является владельцем, вы можете просто использовать$qb->expr()->isNull()
@ Бронча, а как насчет отношений один на один?
Ага :) Я отредактировал мой код
У меня странная проблема, может быть, вы можете помочь?stackoverflow.com/questions/14387797/…
Почти идеально, просто нужно изменить -> gt; join () на -> leftJoin (), потому что в противном случае он ограничивает запрос методами, которые имеют хотя бы одну страну, и возвращает пустой результат. Gnuffo1

Похожие вопросы