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

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/hch15112345824/article/details/79167408

表只有一个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有些条件可以适当不要。




猜你喜欢

转载自blog.csdn.net/hch15112345824/article/details/79167408