Symfony DQL не выполняет подзапрос

Я новичок в DQL, и у меня проблема с подзапросами. Мне нужно получить список идентификаторов видео, которые были добавлены в query2 после последнего выполнения оптимизации.

Symfony выдает мне это исключение:

[Syntax Error] line 0, col -1: Error: Expected Doctrine\ORM\Query\Lexer::T_CLOSE_PARENTHESIS, got end of string.

Я думаю, что ошибка вызвана подзапросом. Ты знаешь почему? Или у вас есть другой, может быть, более простой способ сделать это?

Это мой код:

public function showOptimizable(){
    $query = $this->em->createQuery('
        SELECT e.videoID
        FROM AppBundle:Query2 e
        WHERE e.timestamp < (
                             SELECT MAX(o.lastOptimization)
                             FROM AppBundle:Optimization
                            )
        GROUP BY e.videoID HAVING COUNT(e.videoID) < 3
        ORDER BY e.videoID DESC
         ');

    return $query->getResult();
}

Это query2:

  CREATE TABLE `query2` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `query` varchar(255) COLLATE utf8_unicode_ci NOT NULL,
  `timestamp` datetime NOT NULL,
  `ip` varchar(255) COLLATE utf8_unicode_ci NOT NULL,
  `uAgent` varchar(255) COLLATE utf8_unicode_ci NOT NULL,
  `videoID` varchar(255) COLLATE utf8_unicode_ci NOT NULL,
  `trackTitle` varchar(255) COLLATE utf8_unicode_ci NOT NULL,
  `present` varchar(255) COLLATE utf8_unicode_ci NOT NULL,
  PRIMARY KEY (`id`),
  UNIQUE KEY `UNIQ_2D293848A5D6E63E` (`timestamp`)
)

А это оптимизация:

CREATE TABLE `optimization` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `lastOptimization` datetime NOT NULL,
  `optimizedElements` int(11) NOT NULL,
  PRIMARY KEY (`id`)
)
Стоит ли изучать 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 и хотите разрабатывать...
0
0
109
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Псевдоним «o» отсутствует. Попробуй это:

(
  SELECT MAX(o.lastOptimization)
  FROM AppBundle:Optimization o
)

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