你原来的SQL中已经使用了一次isNULL(),其实,再使用一次就是了,只是要搞清楚括号就好了。
select isNULL(SUM(isNULL(score,0)),0) from ZWY_Subject where Users =11
这样:
SELECT
a.dtAS'时间',
ISNULL(b.yield,'0')AS'数据'
FROM
(
SELECT
dateadd(d,number,'2018-11-01')dt
FROM
master..spt_values
WHERE
type='p'
ANDdateadd(d,number,'2018-11-01')<='2018-11-30'
)a
LEFTJOINCE_BD_E_ELECTRIC_WORKSHIFT_TbONa.dt=b.opdate
扩展资料:
注意事项
COALESCE是一个函数,(expression_1,expression_2, ,expression_n)依次参考各参数表达式,遇到非null值即停止并返回该值。如果所有的表达式都是空值,最终将返回一个空值。使用COALESCE在于大部分包含空值的表达式最终将返回空值。
场景一:你想要获取最大值,然后+1返回(即返回的值已经默认为空了),程序接收了本来不该为空的值去运算,就会出错。
SELECTMAX(my_money)+1FROMtb_test;
改进方法:使用coalesce函数 COALESCE(值1,值2,......,值n),只要遇到非null值就返回。
这样子就可以设置一个值,让你第一个不成功后,返回指定的值,如下面,返回的是1.
SELECTCOALESCE(MAX(my_money)+1,1)FROMtb_test;
在sqlserver中可以有几种方法:
---方法1:使用isnull替换
select keyId,isnull(info,0) as info from test
---方法2:使用case when 替换
select keyId,case when info is null then 0 else info end as info from test
---方法3:使用coalesce替换相应的值
select keyId , coalesce(info,0) as info from test
版权声明:我们致力于保护作者版权,注重分享,被刊用文章【sql查询总和为空的时候怎么给他赋值为零?】因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理!;
工作时间:8:00-18:00
客服电话
电子邮件
beimuxi@protonmail.com
扫码二维码
获取最新动态