限制在Symfony2中使用Doctrine DQL时检索的记录数量

时间:2011-09-13 15:05:31

标签: php sql doctrine-orm symfony dql

我有以下查询:

   $latestcontent = $em->createQuery('
            SELECT c.title, c.content, c.lastedit, a.firstname, a.surname
            FROM ShoutMainBundle:Content c, ShoutMainBundle:Admin a
            WHERE c.author = a.id
            ORDER BY c.lastedit ASC'
            );

我需要做的是限制从此查询返回的记录数量。但是,当我将LIMIT 10添加到SQL查询时,它会返回以下错误:

  

错误:字符串的预期结束,得到'LIMIT'。

所以,我看了一下,发现你可以在代码中添加->limit(10)(在查询之后)。但是这会引发这个PHP错误:

Fatal error: Call to undefined method Doctrine\ORM\Query::limit() in C:\wamp\www\src\Shout\AdminBundle\Controller\DefaultController.php on line 22

我做错了什么?

1 个答案:

答案 0 :(得分:58)

据我所知,目前没有像LIMIT这样的声明。

您必须使用Query::setMaxResults()