表名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的了~~解决 无用评论 打赏 举报
悬赏问题
- ¥50 成都蓉城足球俱乐部小程序抢票
- ¥15 yolov7训练自己的数据集
- ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
- ¥15 电力市场出清matlab yalmip kkt 双层优化问题
- ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)
- ¥20 matlab yalmip kkt 双层优化问题
- ¥15 如何在3D高斯飞溅的渲染的场景中获得一个可控的旋转物体
- ¥88 实在没有想法,需要个思路
- ¥15 MATLAB报错输入参数太多
- ¥15 python中合并修改日期相同的CSV文件并按照修改日期的名字命名文件