Я новичок в 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`)
)






Псевдоним «o» отсутствует. Попробуй это:
(
SELECT MAX(o.lastOptimization)
FROM AppBundle:Optimization o
)