sql 子查询中部分数据有空值,怎么返回0,NULL+数字=null出来不可以 5

UPDATEAsetBYZD10=((SELECTdistinct(JF)FROMBwhereVIPBH=V_VIPSET.DMandfx='增加'andLX='99-期... UPDATE A set BYZD10 =((SELECT distinct(JF)
FROM B where VIPBH=V_VIPSET.DM and fx='增加' and LX='99-期末')
+(SELECT distinct(JF) FROM B where VIPBH=V_VIPSET.DM and fx='增加'
and LX='00-期初'))
展开
 我来答
雁子sunshine30
2019-03-21 · TA获得超过289个赞
知道答主
回答量:170
采纳率:0%
帮助的人:6.4万
展开全部

遇到类似问题可以参考这个

comm列有很多记录的值为NULL,因为任何东西与NULL相加结果还是NULL,所以结算结果可能会出现NULL。下面使用了把NULL转换成数值0的函数IFNULL:

SELECT *,sal+IFNULL(comm,0) FROM emp;

micro0369
2014-12-17 · TA获得超过1.2万个赞
知道大有可为答主
回答量:9250
采纳率:85%
帮助的人:4044万
展开全部

如果是sqlserver ,用 isnull,如果是oracle,用nvl,mysql则用 ifnull

UPDATE A set BYZD10 =(isnull(SELECT  distinct(JF)  
FROM B where VIPBH=V_VIPSET.DM and fx='增加' and LX='99-期末'),0)
+(isnull(SELECT  distinct(JF) FROM B where VIPBH=V_VIPSET.DM and fx='增加'
 and LX='00-期初'),0))
追问
语法错误
消息 156,级别 15,状态 1,第 1 行
关键字 'SELECT' 附近有语法错误。
消息 102,级别 15,状态 1,第 2 行
')' 附近有语法错误。
消息 102,级别 15,状态 1,第 4 行
',' 附近有语法错误。
追答
UPDATE A set BYZD10 =isnull((SELECT  distinct(JF)  
FROM B where VIPBH=V_VIPSET.DM and fx='增加' and LX='99-期末'),0)
+isnull((SELECT  distinct(JF) FROM B where VIPBH=V_VIPSET.DM and fx='增加'
 and LX='00-期初'),0))
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式