我正在尝试分页一个使用DQL的查询(因为我要使用一些组函数,比如sum),并且有一个外部联接,这里是一个简化的代码:
//in controller
use
Pagerfanta\Pagerfanta,
Pagerfanta\Adapter\DoctrineORMAdapter as PagerAdapter;
//in list action
$query=$em->createQuery(
'select m,sum(d.amount) from
ABundle:Master m
left join ABundle:Detail d with d.master=m
group by m.date'
);
$query->setHint(Query::HINT_CUSTOM_OUTPUT_WALKER, true);
$paginator=new Pagerfanta(new PagerAdapter($query));
$paginator->setMaxPerPage($this->getPerPage());
$paginator->setCurrentPage($this->getPage(),false,true);
return $paginator;问题是,我得到了以下错误:
An exception has been thrown during the rendering of a template ("Cannot count query which selects two FROM components, cannot make distinction")我一直在尝试设置一个名为HINT_CUSTOM_OUTPUT_WALKER的提示,这样页面幻想可以使用我的查询作为视图并运行它自己的计数,但我一直无法解决这个问题。
有人能给我一些关于如何正确使用它的指导吗?
发布于 2013-11-21 15:17:48
相反,它使用页面幻想数组适配器,使用左联接运行查询,然后用结果对数组进行分页。
https://stackoverflow.com/questions/19306547
复制相似问题