Doctrine2 - проблема с двойным левым соединением - PullRequest
0 голосов
/ 09 июня 2018

Я использую 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'

Ответы [ 2 ]

0 голосов
/ 09 июня 2018

Нет необходимости использовать предложение WITH, если вы определили отображение в ваших сущностях, предложение WITH используется, когда вы хотите объединить свои сущности с дополнительными критериями соответствия

class User
{
    /**
     * @ORM\YourRelationShipNature(targetEntity="App\Entity\Firm", mappedBy="user")
     */
    private $userFirm;
}

class Firm
{
    /**
     * @ORM\YourRelationShipNature(targetEntity="App\Entity\Shop", mappedBy="firm")
     */
    private $firmShop;
}


class Shop
{
    //.....
}

И затемВы можете просто использовать свойства, чтобы присоединиться к вашим энтитам

$query = $em->createQueryBuilder()
    ->select('u, f, s')
    ->from('App:User', 'u')
    ->leftJoin('u.userFirm', 'f')
    ->leftJoin('f.firmShop', 's')
    ->where('u.id = :user_id')
    ->setParameter('user_id', $user_id)
    ->getQuery();
0 голосов
/ 09 июня 2018

Я думал о чем-то более похожем на это (предполагая, что имена сущностей правильные):

$query = $em->createQueryBuilder()
    ->select('u, f, s')
    ->from('App:User', 'u')
    ->leftJoin('App:UserFirm f WITH f.firmUser = u')
    ->leftJoin('App:FirmShop s WITH s.shopFirm = f')
    ->where('u.id = :user_id')
    ->setParameter('user_id', $user_id)
    ->getQuery();
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...