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

我使用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 + 接收到的数。请问有没有更好的办法?

谢谢大神了!

数据字段被设置为允许为空, 那么默认值是不起作用的. 所以, 在插入数据时如果不指定那个字段的值, 那么其值肯定为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
温馨提示:答案为网友推荐,仅供参考
第1个回答  2013-08-07
改成这样就好了
update tableName set num=isnull(num,0) + isnull(接收到的数,0) where id=XXX本回答被网友采纳
第2个回答  2013-08-07
update tableName set num=isnull(num,0) + 接收到的数

要这样?
第3个回答  2013-08-07
设置了默认值,设为允许为空?????
这不是给自己找麻烦吗.
不允许空
第4个回答  2013-08-07
不允许空不行吗?
相似回答