mysql - 如果没有找到值,如何在 MySQL 中获取 SUM 函数以返回 '0'?

标签 mysql function null sum

假设我在 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 fiddle:http://www.sqlfiddle.com/#!2/d1542/3/0


更多信息:

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

SQL Fiddle

MySQL 5.5.32 架构设置:

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);

查询 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

Results :

| 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 - 如果没有找到值,如何在 MySQL 中获取 SUM 函数以返回 '0'?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7602271/

相关文章:

mysql - mysql如何更快地插入百万条记录?

javascript - 这个数组过滤器中的函数是如何工作的?

C 函数将指针字符串的第一个字符大写

json - 使用 jq 过滤空值和/或空值

c - 如何知道数组是否在C中初始化

php - 使用带有占位符的 Laravel 原始查询

javascript - 单击按钮删除 MySQL 中的任何行

mysql - 选择首先计数或数据以检查自动增量 ID

javascript - 如何在不返回内部函数的情况下访问函数内部函数

java - for 内变量的空指针访问