版权声明:本文为博主原创文章,未经博主允许不得转载。 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有些条件可以适当不要。