Symfony DQL不执行子查询

时间:2018-03-29 08:14:21

标签: php database symfony subquery dql

我对DQL很新,我遇到子查询问题。 我需要获取在上次执行优化后在 query2 中添加的videoID列表。

Symfony给我这个例外:

  

[语法错误]第0行,第1行:错误:预期的Doctrine \ ORM \ Query \ Lexer :: T_CLOSE_PARENTHESIS,得到了字符串的结尾。

我认为错误是由子查询生成的。 你知道为什么吗?或者你有另一种方式 - 也许更简单 - 这样做?

这是我的代码:

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`)
)

1 个答案:

答案 0 :(得分:0)

缺少别名“o”。试试这个:

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