编辑:
进一步的研究:看来答案就在于为一个定制的昌宁默认保湿剂。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/

10-08 21:35