编辑:
进一步的研究:看来答案就在于为一个定制的昌宁默认保湿剂。doctrine2允许您通过将他的名字作为参数发送来更改它:
$query->getresult('customhyderor');
不要忘记先在config.yml文件中注册它:
doctrine:
orm:
hydrators:
CustomHydrator: \your\bundle\Hydrators\CustomHydrator
我的博客和评论实体是一对多的关系。1个博客有n条评论
在研究了如何在原则2中为获取的对象添加一个额外字段之后,我发现Aggregate Fields,这是一篇很好的文章,但只是讨论如何从一个帐户中获得余额,它从不说我们在处理一系列帐户时应该做什么,这听起来可能很傻,但让我解释一下我的情况。
在我的案例中,不是关于帐户和条目,而是关于博客和评论。
我要做的是列出一些博客,只显示它有多少评论,而不加载任何评论信息,换句话说,我想把这个查询翻译成doctrine2世界。
'SELECT b.*, COUNT( b.id ) AS totalComments FROM `blogs` b LEFT JOIN comments c ON b.id = c.blog_id GROUP BY b.id LIMIT 8'
我希望得到的结果是一个blog对象数组,其totalcomments属性设置正确,如下所示:
array (size=8)
0 =>
object Blog
'id' => int 330
'title' => string 'title blog'
// Added field, not visible in table DB. Came through query COUNT() statement
'totalComments' => int 5
// ... more attributes
1 => ...
//more object blogs
);
我就是做不到,我能做的就是:
创建和获取查询:
$qb = $this->createQueryBuilder('b')
->select('b, c')
->addSelect('count(b.id) as nComments')
->leftJoin('b.comments', 'c')
->groupBy('b.id')
return $qb->getQuery()->getResult();
我得到的结果是一个数组,其中位置0有blog对象和位置“totalcomments”
// var_dump($result)
array (size=8)
0 =>
array(2) =>
0 =>
object Blog
'id' => int 330
'title' => string 'title blog'
// ... more attributes
"totalComments" => int 5
1 => ...
);
我也试着自己做补水器,但我刚开始使用医生2,发现自己有点迷路了。
我希望已经足够清楚了。如果需要,我可以提供任何其他信息。
提前谢谢!
最佳答案
您要么必须命名所需的字段,要么得到一个混合结果(如第二个示例)。所以对于平面阵列:
$qb = $this->createQueryBuilder('b')
->select('b.title, b.author')
->addSelect('count(c.id) as nComments')
->leftJoin('b.comments', 'c')
->groupBy('b.id')
return $qb->getQuery()->getArrayResult();
或者是一个混合的结果:
$qb = $this->createQueryBuilder('b')
->select('b')
->addSelect('count(c.id) as nComments')
->leftJoin('b.comments', 'c')
->groupBy('b.id')
return $qb->getQuery()->getResult();
关于php - 将字段聚合到Doctrine2中的Fetched Objects,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/27511434/