tp5使用sum()聚合函数分组查询

数据查询出来大概是这个样子(实际应用中会很复杂,这里造一些类似的数据,用来举例说明)

 简单的查询

$data = Db::name('order')
    ->field('sum(money) as moneys')
    ->where($where)
    ->select();

这个只能是简单的将所有的money字段的值加在一起

如果我的from_type是三个不通的来源,我想统计每个来源下的和,同时按照商品名字分组

$data = Db::name('order')
    ->field('id,name,sum(if(from_type = 1,money,0)) as one,sum(if(from_type = 1,money,0)) as two,sum(if(from_type = 1,money,0)) as three')
    ->where($where)
    ->group('name')
    ->select();
if(from_type = 1,money,0)

可以理解为,判断from_type子弹是否等于1,如果是吧money的值加上,如果不是,就加上0,类似于三元运算符的感觉

同样,也适用于,count(),avg()这些聚合函数.

同样解决这些问题,也可以直接查询出所有的订单数据,然后foreach遍历,加上if判断,一个一个加上,也能处理.

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值