[求助] sql count 函数加条件的问题

2016-08-23 16:46:22 +08:00
 wanderingFaker

select w.xm,w.wgfwzb,COUNT(username ) '需求总数' from t_wgy w left join t_sq_xqdj x on w.sjh=x.wgytel group by w.sjh

这是执行的 sql ,现在要在需求总数的基础 ,查已完成需求总数。想知道怎样在 count 里加 where 条件

397 次点击
所在节点    问与答
3 条回复
liprais
2016-08-23 16:50:08 +08:00
count( case when done then 'done' else null end)
count 不计算 null
wanderingFaker
2016-08-23 17:13:25 +08:00
select w.xm,w.wgfwzb,COUNT(case x.username when x.xqzt=1 then 1 else 0 end ) '已完成需求总数'
from t_wgy w left join t_sq_xqdj x on w.sjh=x.wgytel group by w.sjh ;

select w.xm,w.wgfwzb,COUNT(x.username ) '需求总数'
from t_wgy w left join t_sq_xqdj x on w.sjh=x.wgytel group by w.sjh ;
这样写的。但查出来的有误
liprais
2016-08-23 18:13:41 +08:00
@wanderingFaker
count()是会计算 0 的,所以 else 那里写成 null

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/301233

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX