sql查询总和为空的时候怎么给他赋值为零?
selectSUM(isNULL(score,0))fromZWY_SubjectwhereUsers=11这个查询出来的是一个空值,原因是Users=11在ZWY_Su...
select SUM(isNULL(score,0)) from ZWY_Subject where Users =11这个查询出来的是一个空值,原因是Users=11在ZWY_Subject表中不存在的。但是如果等于12的,score为空的话就可以赋值为0。因为Users=12在ZWY_Subject表有数据。求高手解决........
展开
8个回答
展开全部
你原来的SQL中已经使用了一次isNULL(),其实,再使用一次就是了,只是要搞清楚括号就好了。
select isNULL(SUM(isNULL(score,0)),0) from ZWY_Subject where Users =11
select isNULL(SUM(isNULL(score,0)),0) from ZWY_Subject where Users =11
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
做一次isnull判断即可:
select isNULL(SUM(score),0) from ZWY_Subject where Users =11
select isNULL(SUM(score),0) from ZWY_Subject where Users =11
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
参考以下文句(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
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
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
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
FROM (select SUM(isNULL(score,0)) total ,
count(score) cnt from ZWY_Subject where Users =11) t
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
其实不难,一看你就懂了。。
select ISNULL(SUM(isNULL(score,0)),0) from ZWY_Subject where Users =11
select ISNULL(SUM(isNULL(score,0)),0) from ZWY_Subject where Users =11
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询