COALESCE语句解救sql的sum问题

Posted 阿米诚

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了COALESCE语句解救sql的sum问题相关的知识,希望对你有一定的参考价值。

mysql+mybatis有一个sql语句是统计用的

<select id="getNum" resultType="map">

结果是一个map, select语句的结果是一些sum

select sum(t.anum),

          sum(t.bnum)

from tableSum t

where t.id = #{id}

调试发现,数据库明明记录已经落入,但是查出来的对象为null,

把sum部分写成 固定的数值问题就不存在,所以应该是sum的部分的问题。

解决方法用COALESCE 函数

 

COALESCE(SUM(t.anum),0) AS anum
改成这样,初始为0,就永远有值,不为null啦。

 

以上是关于COALESCE语句解救sql的sum问题的主要内容,如果未能解决你的问题,请参考以下文章

如何在 Javascript 中模拟 SQL Coalesce 语句的功能

SQL nvl 等效 - 没有 if/case 语句 & isnull & coalesce

sql在查询之间不显示空值

将此 SQL 语句转换为 Laravel ORM

MySQL 在 WHERE 语句中使用 COALESCE 或 IFNULL 选择非 NULL 值

BigQuery COALESCE/IFNULL 类型与文字不匹配