勉強したことのメモ

Webエンジニア / プログラマが勉強したことのメモ。

MySQLで特定の値を加算しつつNULL値の場合は0にする方法

   2024/04/20  MySQL

いくつかのコードに対して投票を行い、その合計値をスコアとして出したい。ただ、投票されなかったり開催直後は当然0になるはずだけど、MySQLではNULLが返される。そのため、特定の値を加算しつつNULL値の場合は0にする方法をメモ。

 

ソースコード

SELECT
    p.code , COALESCE(SUM(g.score),0) AS p_score
FROM
    table_p AS p
LEFT JOIN
    table_g AS g
ON p.code = g.code
WHERE p.e_code = xxxxxxxx
GROUP BY p.code

 

COALECE

https://dev.mysql.com/doc/refman/8.0/ja/comparison-operators.html#function_coalesce

リストの最初の非 NULL 値を戻すか、非 NULL 値がない場合は NULL を戻す。

 

参考サイト

http://detail.chiebukuro.yahoo.co.jp/qa/question_detail/q1014972535

 - MySQL

  関連記事

adminerでMySQLに接続しようとするとエラーになる場合の対応方法

新しく構築したサーバにadminerを入れて接続しようとすると、「mysqlnd ...

MySQLでストアドプロシージャ戻り値対応版であるストアドファンクションの設定と利用方法

先日MySQLのストアドプロシージャに関するメモを書いたが、今回はストアドファン ...

MySQLでdatetime型にもインデックスを使用して高速化を図る方法

ログ関連のデータを格納するテーブルがあり、集計を行う際に非常に時間がかかった。レ ...

MySQLで同一サーバーの異なるDB内のテーブルをJOINする

同一のMySQLサーバーでdb1データベースのtable1テーブルと、db2デー ...

MySQLで経度緯度から半径○Kmのデータを抽出する方法

経度と緯度をtext型として格納しているMySQLのテーブルがあり、指定した経度 ...