2 u010340708 u010340708 于 2014.02.22 07:59 提问

请教大神一条sql语句的优化
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
求教各位大神该怎么优化?

2个回答

Ouvidia
Ouvidia   2014.02.22 17:50

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的了~~

shendixiong
shendixiong   2014.04.04 11:33
   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 ;

就可以了

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!