zoukankan      html  css  js  c++  java
  • 如何解决数据库中,数字+null=null

    如何解决数据库中,数字+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

  • 相关阅读:
    linux下yum无法使用
    判断某个网卡是否是dhcp获取的ip
    个人作业---词频统计
    第四周读书笔记
    设计关键词
    好文收藏
    Apritag角点代码检测
    处理txt文件,保存为yml和cal文件
    欧拉角欧拉矩阵
    Mysql笔记01-安装和SQL基础
  • 原文地址:https://www.cnblogs.com/firstdream/p/5695213.html
Copyright © 2011-2022 走看看