Я использую Symfony v3.4 branch
с Doctrine
.
У меня проблемы с переводом SQL-запроса в Doctrine ORM.
У меня 3 таблицы.
- Магазин
- Фирма
- Пользователь
Пользователь -> 1: 1 -> Фирма -> 1: 1 -> Магазин
(Панель инструментов разработчика Symfony сообщает, что связи в таблицах сделаны правильно).
Я хочу получить Shop
данные, которые соответствуют cretain User
в одном запросе.
Мой SQL, который получает результат:
SELECT *
FROM mp2_fos_user as u
LEFT JOIN mp2_firm AS f ON u.id = f.firmUserId
LEFT JOIN mp2_shop AS s ON f.id = s.shopFirmId
WHERE u.id = 1
Мой запрос Doctrine ORM
$query = $em->createQueryBuilder()
->select('u, f, s')
->from('App:User', 'u')
->leftJoin('u.userFirm WITH u.id = f.firmUserId', 'f')
->leftJoin('f.firmShop WITH f.id = s.shopFirmId', 's')
->where('u.id = :user_id')
->setParameter('user_id', $user_id)
->getQuery();
в момент запуска кода приводит кошибка
[Syntax Error] line 0, col 57: Error: Expected end of string, got 'u'
Что было бы лучшим решением для моей проблемы?
Помощь будет высоко ценится, спасибо!
ОБНОВЛЕНИЕ
попробовал:
$query = $em->createQueryBuilder()
->select('s.id')
->from('App:User', 'u')
->leftJoin('u.userFirm WITH f.firmUser = u', 'f')
->leftJoin('f.firmShop WITH s.shopFirm = f', 's')
->where('u.id = :user_id')
->setParameter('user_id', $user_id)
->getQuery();
получил [Syntax Error] line 0, col 54: Error: Expected end of string, got 'f'