MySQLNULL値
NULL値とは何ですか?
NULL値のあるフィールドは、値のないフィールドです。
テーブルのフィールドがオプションの場合、このフィールドに値を追加せずに、新しいレコードを挿入したり、レコードを更新したりすることができます。次に、フィールドはNULL値で保存されます。
注: NULL値は、ゼロ値またはスペースを含むフィールドとは異なります。NULL値を持つフィールドは、レコードの作成中に空白のままにされたフィールドです。
NULL値をテストする方法は?
=、<、<>などの比較演算子を使用してNULL値をテストすることはできません。
IS NULL
代わりにand
IS NOT NULL
演算子を使用する必要があります。
ISNULL構文
SELECT column_names
FROM table_name
WHERE column_name IS NULL;
IS NOTNULL構文
SELECT column_names
FROM table_name
WHERE column_name IS NOT NULL;
デモデータベース
以下は、Northwindサンプルデータベースの「Customers」テーブルからの抜粋です。
CustomerID | CustomerName | ContactName | Address | City | PostalCode | Country |
---|---|---|---|---|---|---|
1 |
Alfreds Futterkiste | Maria Anders | Obere Str. 57 | Berlin | 12209 | Germany |
2 | Ana Trujillo Emparedados y helados | Ana Trujillo | Avda. de la Constitución 2222 | México D.F. | 05021 | Mexico |
3 | Antonio Moreno Taquería | Antonio Moreno | Mataderos 2312 | México D.F. | 05023 | Mexico |
4 |
Around the Horn | Thomas Hardy | 120 Hanover Sq. | London | WA1 1DP | UK |
5 | Berglunds snabbköp | Christina Berglund | Berguvsvägen 8 | Luleå | S-958 22 | Sweden |
ISNULL演算子
演算子は、IS NULL
空の値(NULL値)をテストするために使用されます。
次のSQLは、「アドレス」フィールドにNULL値を持つすべての顧客をリストします。
例
SELECT CustomerName, ContactName, Address
FROM Customers
WHERE Address
IS NULL;
ヒント: NULL値を探すには、常にISNULLを使用してください。
IS NOTNULL演算子
演算子は、IS NOT NULL
空でない値(NOT NULL値)をテストするために使用されます。
次のSQLは、「アドレス」フィールドに値を持つすべての顧客を一覧表示します。
例
SELECT CustomerName, ContactName, Address
FROM Customers
WHERE Address
IS NOT NULL;