在 Symfony 3.4 Easy Admin 包中显示大量实体的聚合计数

它是

我正在尝试为实体列表视图显示相关实体的数量,但数量太多,因此它count($this->relatedEntities)在实体中耗尽了内存(它做了一个简单的)。

知道如何/在哪里可以覆盖ListControllerofQueryBuilder以添加聚合COUNT()列吗?

我尝试扩展AdminController和挂钩到findAll()函数中(手动为每个对象添加一个计数),但这并没有给我一个实体列表而是一个Pagerfanta对象。

它是

这是我修复它的方法:

覆盖自定义 AdminController 中的 renderTemplate:

protected function renderTemplate($actionName, $templatePath, array $parameters = array())
{
    if ($actionName === 'list' && $this->entity['class'] === ClassA::class) {
        //piggyback on virtual property 'count'
        $parameters['fields']['count']['servicecounts'] = $this->MyEntityRepository->getCounts();
    }

    return $this->render($templatePath, $parameters);
}

easy_admin 配置:

  list:
    fields:
    - { property: 'count', template: 'count.html.twig' }

count.html.twig:

{{ field_options.servicecounts[item.id] }}

getCounts 函数:

public function getCounts()
{
    $qb = $this->getEntityManager()->createQueryBuilder();

    $qb
        ->select('s.id, count(ce.recordId)')
        ->from(ClassA::class, 's')
        ->leftJoin(ClassB::class, 'ce', Join::WITH, 's.id = ce.service')
        ->groupBy('s.id')
    ;

    $results = [];
    foreach ($qb->getQuery()->execute() as $row) {
        $results[$row['id']] = $row[1];
    }

    return $results;

}

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章