勉強したことのメモ

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で開始から終了日付内を調べたいとき

等号不等号でもできるけど、BETWEENというのがよさそう。 ■参考サイト ht ...

MySQLでIPアドレスを数値として入れると変な値になる場合の対処方法

MySQLでIPアドレスをINET_ATON関数を用いてINT型に変換し格納する ...

MySQLで全国の市区町村のデータを入手し、抽出する方法

都道府県と市区町村が連携したセレクトメニューを作成したかった。具体的には大阪府を ...

MySQLで大文字小文字

半角英数字のみのフォームで入力した値を検索した際、 データに差異が発生。 [Aa ...

MySQLで月別に集計を行う。あと日付時刻関数。

現在進行形でやっているデータ集計系だけど 新たな発見があったのでメモ。 ■日付時 ...