问题描述
- 请教大神一条sql语句的优化
-
表名pm,以temp分组,count两个信息,一个是全部个数,另一个是status为1
id temp status
1 1 0
2 1 1
3 2 0
4 2 1
5 2 1
select total.temp ,used.c1,total.c2
from (select temp,count(1) c1 from pm group by temp ) total
left join (select temp,count(1) c2 from pm where status=‘1’ group by temp ) used
on total.temp=used.temp
求教各位大神该怎么优化?
解决方案
status 为1或者为0 ~~ 那么直接count(status) 不就得到了呀~~?
select temp,count(1),count(status) from pm group by temp;
如果status还有其他值
select temp,count(1),count(1-sign(status-1)*sign(status-1)) from pm group bu temp;
我感觉计算 运算 应该不会太耗时间吧~~ 呵呵!!
1-sign(status-1)*sign(status-1) 这个是 如果不为1 那么sign-1 一定不是0 不是0的平凡 显然是正的1 所以 1-1 显然就是0 了~~ 最终累计的就是status 为1的了~~
解决方案二:
select
temp,
count(case when status =‘1’then status end) used ,
count(case when status !=‘1’then status end) total
from pm
group by temp ;
就可以了
时间: 2024-07-28 16:45:42