LaravelORM 中的 withSum , withAvg, withMax,withMin 的实现

laravelORM 中的 withCount 可以统计相关联数据的总数 ,
LaravelORM 写法:

Orm::withCount(['relation'])->get();

解析成SQL :

select `a`.*, (select count(*) from `relation` where `a`.`id` = `relation`.`aid`) as `relation_count` from `a`;

当需要统计关联的 某个字段 sum 时,可以这样写:

Orm::withCount(['relation as relation_sum' =>function($query){
    $query->select(DB::raw("sum(amount) as relationsum"));
}])

解析成SQL:

select `a`.*, (select sum(amount) from `relation` where `a`.`id` = `relation`.`aid`) as `relation_sum_count` from `a` ;

其他的avg , max , min也可以通过withCount实现

本帖已被设为精华帖!
本帖由系统于 4年前 自动加精
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 9

新技能get :smile:

6年前 评论
Toiu

:+1:

5年前 评论

厉害厉害

4年前 评论

多态一对一貌似不行

4年前 评论

我觉得你可以贴个二维码,接收捐赠了,这个功能太赞了

3年前 评论

前些日子,把你这篇文章推荐给 laravel 官方,没通过的 pr 现在官方已经支持了

laravel 8.13 更新

3年前 评论
韩众

@tu6ge-php 感谢提出官方解决方案

3年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!