mysql: sum如何处理null值 以及 当sum(字段)值为null时,默认为0

1 篇文章 0 订阅

一:首先要明确,mysql中 sum() 函数是不统计null的,即使是sum(多个字段),其中某一个字段为null也不行

例: id   val 

      1     1

      2   null

      3     3

sum(val) 结果为4,在计算是null值不会转为0进行相加,而是直接舍去

sum(id + val) 结果为8,其中第二行因为val=null ,所以整个舍去;

二:在统计数据时,如果结果为null,怎么转成0呢?

1.语法: IFNULL(字段,默认值)           即: IFNULL(字段,0)

2.使用COALESCE函数,改函数依次判断所有条件并且返回第一个不为null的值,

  语法:COALESCE(字段1,字段2......)      即: COALESCE(sum(字段),0)

3.case WHEN 条件1 THEN 结果1  .. ELSE 其余结果 END 

   即: case when isnull(sum(字段)) then 0 else sum(字段) end

 

  • 7
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值