首页 >数据库 >mysql教程 >如何在 Laravel Eloquent 中高效地对数据进行求和和分组?

如何在 Laravel Eloquent 中高效地对数据进行求和和分组?

DDD
DDD原创
2024-12-31 17:07:16839浏览

How to Efficiently Sum and Group Data in Laravel Eloquent?

如何在 Laravel 中使用 Eloquent 进行求和和分组

在此查询中,目标是利用 Eloquent 来计算特定列,同时根据另一列对结果进行分组。问题中给出的示例,其中 no_of_pages 列的总和需要按 users_editor_id 进行分组,作为实际说明。

问题中提供的初始尝试存在逻辑问题。由于 sum() 立即运行查询并返回结果,因此在处理查询后会尝试进行分组。 Laravel 不支持在执行查询后应用分组,因此会出现错误。

要解决此问题,需要更改查询结构。不要在 sum() 之后使用 groupBy(),而是首先使用 groupBy('users_editor_id') 对结果进行分组。这将有效地为每个唯一的 users_editor_id 值创建子查询。

接下来,添加 selectRaw() 子句以指定分组结果中感兴趣的列。在本例中,它是聚合总和: sum(no_of_pages) as sum。

最后,使用 pluck() 从结果中仅提取 sum 和 users_editor_id 列。这将返回一个数组,其中 users_editor_id 作为键,相应的总和作为值。

这是修改后的查询:

Document::groupBy('users_editor_id')
   ->selectRaw('sum(no_of_pages) as sum, users_editor_id')
   ->pluck('sum','users_editor_id');

另一种方法是使用 selectRaw() 子句包括 sum(no_of_pages) 作为子查询中的附加列。但是,此方法会生成一个伪模型集合,其中包含原始列和作为附加字段的计算总和。

Document::groupBy('users_editor_id')
   ->selectRaw('*, sum(no_of_pages) as sum')
   ->get();

以上是如何在 Laravel Eloquent 中高效地对数据进行求和和分组?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn