如何在 Laravel Eloquent 中使用 GroupBy 高效执行求和聚合?
Jan 03, 2025 am 08:25 AMLaravel Eloquent 中使用 GroupBy 进行求和聚合
简介:
Laravel 的 Eloquent ORM 提供了一种便捷的方法来检索和操作来自数据库。当处理大型数据集时,有必要对数据进行分组并执行求和等聚合。
问题陈述:
提供的代码尝试计算按 users_editor_id 分组的 no_of_pages 的总和使用 Eloquent 的 sum() 和 groupBy() 方法。但是,这种方法会失败,因为 sum() 在应用 groupBy() 之前执行查询并返回结果。
解决方案:
解决这个问题,我们可以结合使用 groupBy() 和 selectRaw() 方法。这是更新的解决方案:
Document::groupBy('users_editor_id') ->selectRaw('sum(no_of_pages) as sum, users_editor_id') ->pluck('sum','users_editor_id');
登录后复制
说明:
- groupBy('users_editor_id'):按 users_editor_id 列对行进行分组。
- selectRaw('sum(no_of_pages) as sum, users_editor_id'): 在结果中添加一个名为 sum 的新列,其中包含每个组的 no_of_pages 的总和。
- pluck('sum','users_editor_id'): 检索总和和 users_editor_id 值并返回它们作为数组。
替代解决方案:
另一种方法是使用 selectRaw() 方法和 get() 一起返回伪 ORM 模型的集合:
Document::groupBy('users_editor_id') ->selectRaw('*, sum(no_of_pages) as sum') ->get();
登录后复制
此方法将总和相加每个结果模型的列,允许您像常规模型一样访问它
结论:
通过利用 groupBy()、selectRaw() 和 pluck() 方法,我们可以在 Laravel Eloquent 中通过分组高效地执行求和聚合。这些技术使我们能够有效地处理大型数据集并从数据中检索有价值的见解。
以上是如何在 Laravel Eloquent 中使用 GroupBy 高效执行求和聚合?的详细内容。更多信息请关注PHP中文网其他相关文章!
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门文章
击败分裂小说需要多长时间?
3 周前
By DDD
仓库:如何复兴队友
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前
By 尊渡假赌尊渡假赌尊渡假赌
公众号网页更新缓存难题:如何避免版本更新后旧缓存影响用户体验?
3 周前
By 王林

热门文章
击败分裂小说需要多长时间?
3 周前
By DDD
仓库:如何复兴队友
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前
By 尊渡假赌尊渡假赌尊渡假赌
公众号网页更新缓存难题:如何避免版本更新后旧缓存影响用户体验?
3 周前
By 王林

热门文章标签

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

在 Linux 中运行 MySQl(有/没有带有 phpmyadmin 的 podman 容器)
