如何使用Laravel进行一对多关联的复杂聚合查询?
- 内容介绍
- 文章标签
- 相关推荐
本文共计847个文字,预计阅读时间需要4分钟。
直接使用 `withCount()` 或 `withSum()` 函数,无需手动编写子查询或循环系统计——这是最安全、最高效、也最符合 Eloquent 设计意图的做法。
什么时候必须用 withCount() 而不是 $user->posts->count()
当你需要在「一次查询」中获取多个用户的关联数量时,$user->posts->count() 会触发 N+1:先查出所有用户,再为每个用户单独执行 SELECT COUNT(*) FROM posts WHERE user_id = ?。100 个用户就是 100 次 COUNT 查询。
本文共计847个文字,预计阅读时间需要4分钟。
直接使用 `withCount()` 或 `withSum()` 函数,无需手动编写子查询或循环系统计——这是最安全、最高效、也最符合 Eloquent 设计意图的做法。
什么时候必须用 withCount() 而不是 $user->posts->count()
当你需要在「一次查询」中获取多个用户的关联数量时,$user->posts->count() 会触发 N+1:先查出所有用户,再为每个用户单独执行 SELECT COUNT(*) FROM posts WHERE user_id = ?。100 个用户就是 100 次 COUNT 查询。

