Значения MySQL NULL
Что такое значение NULL?
Поле со значением NULL — это поле без значения.
Если поле в таблице является необязательным, можно вставить новую запись или обновить запись без добавления значения в это поле. Затем поле будет сохранено со значением NULL.
Примечание. Значение NULL отличается от нулевого значения или поля, содержащего пробелы. Поле со значением NULL — это поле, которое было оставлено пустым при создании записи!
Как проверить значения NULL?
Невозможно проверить значения NULL с помощью операторов сравнения, таких как =, < или <>.
Вместо этого нам придется использовать операторы IS NULL
и .
IS NOT NULL
ЕСТЬ НУЛЕВОЙ Синтаксис
SELECT column_names
FROM table_name
WHERE column_name IS NULL;
НЕ NULL Синтаксис
SELECT column_names
FROM table_name
WHERE column_name IS NOT NULL;
Демонстрационная база данных
Ниже приведена выборка из таблицы «Клиенты» в образце базы данных «Борей»:
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 |
Оператор IS NULL
Оператор IS NULL
используется для проверки пустых значений (значений NULL).
Следующий SQL перечисляет всех клиентов со значением NULL в поле «Адрес»:
Пример
SELECT CustomerName, ContactName, Address
FROM Customers
WHERE Address
IS NULL;
Совет. Всегда используйте IS NULL для поиска значений NULL.
Оператор IS NOT NULL
Оператор IS NOT NULL
используется для проверки непустых значений (значений NOT NULL).
Следующий SQL перечисляет всех клиентов со значением в поле «Адрес»:
Пример
SELECT CustomerName, ContactName, Address
FROM Customers
WHERE Address
IS NOT NULL;