如何解决数据库中,数字+null=null

我使用SQLServer,做一个update操作,累计一个数。在数据库中,为了方便,数据库中这个字段我设为允许为空,并且设置了默认值为0。但是在新增的数据中心,那个字段还... 我使用SQLServer,做一个 update 操作,累计一个数。在数据库中,为了方便,数据库中这个字段我设为允许为空,并且设置了默认值为 0 。但是在新增的数据中心,那个字段还是为 null,做 update操作时的SQL为:update tableName set num=num + 接收到的数 where id=XXX ; 犹豫刚开始 num 为null ,所以 update后依然为空?要怎么解决这个问题?

ps:我的解决办法是在update前先查一次这个num,如果num为空,就直接update num=接收到的数,如果num > 0,再update num=num + 接收到的数。请问有没有更好的办法?

谢谢大神了!
展开
 我来答
Andy_Sun321
推荐于2017-09-16 · TA获得超过1376个赞
知道小有建树答主
回答量:811
采纳率:89%
帮助的人:726万
展开全部
数据字段被设置为允许为空, 那么默认值是不起作用的. 所以, 在插入数据时如果不指定那个字段的值, 那么其值肯定为null. 还有, 数据库字段的运算中, null与任何值运算的结果都是null, 这点要切记.
可以使用isnull函数指定在其值为null情况下的取值:
update tableName set num = isnull(num, 0) + 接收到的数 where id=XXX
也可以使用case when来进行条件判断取值:
update tableName set num = ( case when num is null then 0 when num > 0 then num else 小于等于0情况下的值 end ) + 接收到的数 where id=XXX
百度网友7558ae7
2013-08-07 · TA获得超过5797个赞
知道小有建树答主
回答量:1730
采纳率:50%
帮助的人:1698万
展开全部
改成这样就好了
update tableName set num=isnull(num,0) + isnull(接收到的数,0) where id=XXX
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
twvampire
2013-08-07 · TA获得超过3620个赞
知道大有可为答主
回答量:3029
采纳率:76%
帮助的人:2986万
展开全部
update tableName set num=isnull(num,0) + 接收到的数

要这样?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
mms85840884
2013-08-07 · TA获得超过159个赞
知道答主
回答量:270
采纳率:0%
帮助的人:104万
展开全部
设置了默认值,设为允许为空?????
这不是给自己找麻烦吗.
不允许空
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
妙哉不言诗c
2013-08-07 · TA获得超过438个赞
知道小有建树答主
回答量:377
采纳率:0%
帮助的人:272万
展开全部
不允许空不行吗?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式