MySQLで特定の値を加算しつつNULL値の場合は0にする方法
2024/04/20
いくつかのコードに対して投票を行い、その合計値をスコアとして出したい。ただ、投票されなかったり開催直後は当然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
関連記事
-
-
PHPでmysqli関数使用時のプリペアドステートメントの利用方法
PHPでMySQLを扱う際はmysqli関数を、エスケープの際はreal_esc ...
-
-
phpMyAdminでのエクスポート/インポート
DBのバックアップを取る際にエクスポート/インポートを行うが、 データ件数が多い ...
-
-
PHP / MySQLで2038年問題の対策
先日打ち合わせの際に「タイムスタンプを使ってユニークキーに云々~~」といったよう ...
-
-
MySQLでカラム数の異なるテーブルを結合する(UNION)
MySQLでカラム数の異なるテーブル同士をUNIONで結合させたかった。ただ、何 ...
-
-
MySQLで直近に挿入したオートインクリメントの値と次回挿入する値を取得する方法
phpとmysqliを使っている中で次回挿入するオートインクリメントの値と、前回 ...