mysql 分组之后每组的最大值减去第二个值

表只有一个C,结果A,结果B都是重表c查询出来的。

步骤1:根据条件查出分组中最大值的数据,当做查询结果A

select C.id,max(power) from C group by C.name

2:根据条件查询分组中第二大的值(这里查询用not in排除最大值之后的第二大值就是最大的了),当做查询结果B

例如: select C.id,max(power) from C where C.power not in A group by C.name

3:用表A left join B(A的数据必须有,B数据可以没有,相减就当作做是差了,注意判断null)

例如:

select A.id,(IFNULL(A.power,0)-IFNULL(B.power,0)) power from A left join B on A.id=B.id

思路大概就是这样子,有条件限制的,查询视图a的时候必须带上,但是视图b有些条件可以适当不要。




  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值