表名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
求教各位大神该怎么优化?
请教大神一条sql语句的优化
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- ausky 2014-02-22 09: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的了~~解决 无用评论 打赏 举报
悬赏问题
- ¥20 腾讯企业邮箱邮件可以恢复么
- ¥15 有人知道怎么将自己的迁移策略布到edgecloudsim上使用吗?
- ¥15 错误 LNK2001 无法解析的外部符号
- ¥50 安装pyaudiokits失败
- ¥15 计组这些题应该咋做呀
- ¥60 更换迈创SOL6M4AE卡的时候,驱动要重新装才能使用,怎么解决?
- ¥15 让node服务器有自动加载文件的功能
- ¥15 jmeter脚本回放有的是对的有的是错的
- ¥15 r语言蛋白组学相关问题
- ¥15 Python时间序列如何拟合疏系数模型