У меня есть два класса в этом примере - DeliveryMethod и Country. Они имеют отношения "многие ко многим" друг с другом.
Что я хочу сделать, это выбрать все методы DeliveryMethods, у которых нет сопоставленных им стран.
Я могу сделать обратное, то есть выбрать все методы доставки, имеющие хотя бы одну страну -
SELECT m FROM DeliveryMethod m JOIN m.countries
Но я не могу понять, как это сделать, выберите, где поле стран пусто. В простом SQL я бы сделал следующее (deliverymethod_country - таблица ссылок):
SELECT m.* FROM deliverymethods m
LEFT JOIN deliverymethod_country dc ON dc.deliverymethod_id = m.id
WHERE dc.deliverymethod_id IS NULL
Однако любой эквивалент DQL этого не работает, например:
SELECT m FROM DeliveryMethod m LEFT JOIN m.countries WHERE m.countries IS NULL
Что дает мне эту ошибку:
[Syntax Error] line 0, col 75: Error: Expected end of string, got 'm'