勉強したことのメモ

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

  関連記事

MySQLにて指定したカラムがNULLもしくは空の場合、あらかじめ決めておいた内容で表示する方法

何らかのフォームとMySQLを組み合わせた際に任意入力の項目はそのカラムがNUL ...

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

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

phpmyadminからプロセスの停止

重たいSQL文を叩いた際、どうにも処理できず メモリ使用率が100%から下がらな ...

MySQLでJOINの高速化

JOINで無茶苦茶悩んだのでメモ。やりたかった事は、MySQLで テーブルAには ...

MySQLにて直近のクエリで発行されたAUTO_INCREMENTの値を取得する方法

やりたかったことは「MySQLで新規登録(INSERT)なら、登録時のAUTO_ ...