1. ホーム
  2. mysql

[解決済み] MySQLのSUM関数で値がない場合に'0'を返すようにするには?

2022-04-24 09:35:51

質問

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


詳細はこちら

3つの表(すべて数字の表、すべてNULLの表、混合表の表)がある。

SQLフィドル

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

結果 :

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