Внутреннее соединение построителя запросов Doctrine с подзапросом

У меня есть этот запрос в SQL, который работает нормально:

SELECT tl.*
FROM table1 tl
INNER JOIN table2 tl2
ON tl.id = tl2.other_id
INNER JOIN
(
   SELECT other_id, MAX(date) maxDATE
   FROM table2
   GROUP BY other_id
) 
tlv2 ON tl2.other_id = tlv2.other_id AND
tl2.date = tlv2.maxDATE WHERE tl.access=0
ORDER BY tlv2.maxDATE DESC

Теперь проблема в том, что я, кажется, не могу понять, как перевести это в построитель запросов Doctrine.

У меня есть это:

$subquery = $this->getEntityManager()->getRepository(Table2::class)
    ->createQueryBuilder('tl2')
    ->select(array('other_id','MAX(date) maxDate'))
    ->groupBy('other_id')
    ->getDQL();
    $qb = $this->createQueryBuilder('tl');
    $qb->select('tl')
       ->innerJoin(Table2::class,'tl2','WITH','tl.id = tl2.other_id')
       ->innerJoin("(".$subquery.")",'tlv2','WITH','tl2.date = tlv2.maxDATE')
       ->where('tl.access = 0')
       ->orderBy('tlv2.maxDATE','DESC');

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

Subquery is not supported here

В строке, где я поставил переменную $subquery.

Кажется, я не могу понять, что я здесь делаю не так. Что я делаю неправильно?

Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
2
0
3 387
1

Ответы 1

как упоминалось здесь, если вы используете ORM, тогда сопоставление не удастся, вы можете запустить это только без гидратации, если вы используете DBAL, только это буду работать, как вы ожидаете

Если вы выберете собственное решение для запросов и по-прежнему нуждаетесь в сопоставленном результате, вы можете использовать \Doctrine\ORM\EntityManager::createNativeQuery с \Doctrine\ORM\Query\ResultSetMapping.

$sql = <<<SQL
    SELECT tl.*
    FROM table1 tl
    INNER JOIN table2 tl2
    ON tl.id = tl2.other_id
    INNER JOIN
    (
       SELECT other_id, MAX(date) maxDATE
       FROM table2
       GROUP BY other_id
    ) 
    tlv2 ON tl2.other_id = tlv2.other_id AND
    tl2.date = tlv2.maxDATE WHERE tl.access=0
    ORDER BY tlv2.maxDATE DESC
SQL;


$rsm = new Query\ResultSetMapping();
$rsm->addEntityResult(Entity::class, 'e');
$rsm->addFieldResult('e','id', 'id');
$rsm->addFieldResult('e','date', 'createAt');

$result = $this->entityManager->createNativeQuery($sql, $rsm)->getResult();

Другие вопросы по теме