この記事では、SQLの集約関数とNULL値の扱いについて詳しく解説します。SQLを使いこなすためには、集約関数の使い方やNULL値との相性を理解することが重要です。具体的な例と共に、どのように効率的にデータを操作できるのかを見ていきましょう。
目次
集約関数とは
集約関数は、複数の行のデータを一つの値にまとめるための関数です。よく使用される集約関数には、`SUM`、`AVG`、`MIN`、`MAX`、`COUNT`などがあります。
関数 | 説明 |
---|---|
SUM | 数値の合計を求める |
AVG | 数値の平均を求める |
MIN | 最小値を求める |
MAX | 最大値を求める |
COUNT | 行数をカウントする |
NULL値とは
NULL値は、データベース内で「未知」または「存在しない」値を表すための特殊な値です。SQLにおいては、NULLはリテラルではなく、特別なマーカーとして扱われます。
集約関数とNULL値の相性
集約関数はNULL値をどのように扱うのか、それが問題になる場面も多いです。一般に、集約関数はNULL値を無視します。しかし、その挙動は関数によって異なる場合もあります。
NULL値の扱い方による分類
関数 | NULL値の扱い |
---|---|
SUM, AVG, MIN, MAX | NULL値を無視する |
COUNT(*) | NULL値もカウントする |
COUNT(column) | NULL値を無視する |
具体的な使用例
-- SUMの例
SELECT SUM(salary) FROM employees WHERE department = 'Sales';
-- AVGの例
SELECT AVG(salary) FROM employees WHERE department = 'Sales';
-- COUNTの例
SELECT COUNT(*) FROM employees;
-- COUNT(column)の例
SELECT COUNT(salary) FROM employees;
NULL値を明示的に扱う方法
COALESCE関数
COALESCE関数は、最初のNULLでない値を返す関数です。これを使うことで、NULL値を任意の値に変換できます。
-- COALESCEの使用例
SELECT COALESCE(salary, 0) FROM employees;
まとめ
SQLの集約関数とNULL値の扱いには注意が必要です。特に、NULL値が含まれている場合、その影響を正確に理解しておくことが重要です。COALESCE関数を使えば、NULL値を任意の値で置き換えることが可能です。これにより、より柔軟かつ正確なデータ操作が可能となります。
created by Rinker
¥4,554
(2025/01/18 14:22:31時点 Amazon調べ-詳細)
コメント