sql查询总和为空的时候怎么给他赋值为零?

select SUM(isNULL(score,0)) from ZWY_Subject where Users =11这个查询出来的是一个空值,原因是Users=11在ZWY_Subject表中不存在的。但是如果等于12的,score为空的话就可以赋值为0。因为Users=12在ZWY_Subject表有数据。求高手解决........

第1个回答  2012-07-10
你原来的SQL中已经使用了一次isNULL(),其实,再使用一次就是了,只是要搞清楚括号就好了。

select isNULL(SUM(isNULL(score,0)),0) from ZWY_Subject where Users =11
第2个回答  2012-07-10
做一次isnull判断即可:

select isNULL(SUM(score),0) from ZWY_Subject where Users =11
第3个回答  2012-07-10
参考以下文句(mysql方法,如需要sqlserver 自行替换)
select
case
when sum is null then 0
else sum
end
from (SELECT sum(id) as 'sum' FROM project_monitor.e_unit
where id =1) as a本回答被提问者和网友采纳
第4个回答  2012-07-10
SELECT CASE WHEN cnt = 0 THEN 0 ELSE total END
FROM (select SUM(isNULL(score,0)) total ,
count(score) cnt from ZWY_Subject where Users =11) t
第5个回答  2012-07-10
其实不难,一看你就懂了。。
select ISNULL(SUM(isNULL(score,0)),0) from ZWY_Subject where Users =11
相似回答