假设我在MySQL中有一个简单的函数:

SELECT SUM(Column_1)
FROM Table
WHERE Column_2 = 'Test'

如果Column_2中没有包含文本"Test"的条目,那么这个函数返回NULL,而我希望它返回0.

我知道类似的问题在这里已经被问了好几次,但我还不能根据我的目的调整答案,所以我很感激能得到一些帮助来解决这个问题.

推荐答案

COALESCE来避免这种结果.

SELECT COALESCE(SUM(column),0)
FROM   table
WHERE  ...

要查看它的实际操作,请查看以下sql FIDLE:http://www.sqlfiddle.com/#!2/d1542/3/0


更多信息:

给出三个表格(一个包含所有数字,一个包含所有空值,一个包含混合):

SQL Fiddle

MySQL 5.5.32 Schema Setup:

CREATE TABLE foo
(
  id    INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
  val   INT
);

INSERT INTO foo (val) VALUES
(null),(1),(null),(2),(null),(3),(null),(4),(null),(5),(null),(6),(null);

CREATE TABLE bar
(
  id    INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
  val   INT
);

INSERT INTO bar (val) VALUES
(1),(2),(3),(4),(5),(6);

CREATE TABLE baz
(
  id    INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
  val   INT
);

INSERT INTO baz (val) VALUES
(null),(null),(null),(null),(null),(null);

Query 1:

SELECT  'foo'                   as table_name,
        'mixed null/non-null'   as description,
        21                      as expected_sum,
        COALESCE(SUM(val), 0)   as actual_sum
FROM    foo
UNION ALL

SELECT  'bar'                   as table_name,
        'all non-null'          as description,
        21                      as expected_sum,
        COALESCE(SUM(val), 0)   as actual_sum
FROM    bar
UNION ALL

SELECT  'baz'                   as table_name,
        'all null'              as description,
        0                       as expected_sum,
        COALESCE(SUM(val), 0)   as actual_sum
FROM    baz

100:

| TABLE_NAME |         DESCRIPTION | EXPECTED_SUM | ACTUAL_SUM |
|------------|---------------------|--------------|------------|
|        foo | mixed null/non-null |           21 |         21 |
|        bar |        all non-null |           21 |         21 |
|        baz |            all null |            0 |          0 |

Mysql相关问答推荐

try 恢复数据库时,如何正确解决行大小太大消息?

如何使RST(*)在巨大的数据集上快速执行?

慢查询日志(log)甚至包括快速查询,因为它包括等待锁定所花费的时间

MySQL:统计单词在单元格中出现的次数,并将数字放在bra中单词的旁边

运行简单查询时Prisma预准备语句错误

Select 并统计所有条目并根据条目对它们进行分组

计算MySQL中的连续出现

检索按键列值分组的最新日期 (MySql)

从三个不同的表中生成两列,并使用分组变量计算这些列的比率

从多到多表中 Select 数据而无需重复

MySQL 每组最大 n 只适用于多行

使用 MySQL LIMIT、OFFSET 进行分页

org.hibernate.InstantiationException:没有实体的默认构造函数::principal.Cliente

如何在sequelize中定义多列的唯一索引

MySQL解释计划中 Select 优化的表的含义

在 MySQL Workbench EER 图中的多个列上创建唯一约束

在另一个 where 语句(子查询?)中使用一个 sql 查询的结果

如何使用 XML_LOAD() 将 XML 文件导入 MySQL 数据库表;功能

从 MySQL JSON 数据类型中提取不带引号的值

数据截断:第 1 行的logo列数据太长