SQL NULL 值

什么是 NULL 值?

具有 NULL 值的字段是没有值的字段。

如果表中的字段是可选的,那么可以插入新记录或更新记录,而不必向此字段添加值。然后,该字段将以 NULL 值保存。

注意:NULL 值不同于零值或包含空格的字段。具有 NULL 值的字段是在记录创建过程中留空的字段!

如何测试 NULL 值?

无法使用比较运算符(例如 =,< 或 <>)测试 NULL 值。

我们必须改用 IS NULLIS NOT NULL 运算符。

IS NULL 语法

SELECT column_names
FROM table_name
WHERE column_name IS NULL;

IS NOT NULL 语法

SELECT column_names
FROM table_name
WHERE column_name IS NOT NULL;

演示数据库

以下是实例中使用的 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

IS NULL 运算符

IS NULL 运算符用于测试空值(NULL 值)。

以下 SQL 列出 "Address" 字段中具有 NULL 值的所有客户:

实例

SELECT CustomerName, ContactName, Address
FROM Customers
WHERE Address IS NULL;

亲自试一试

提示:始终使用 IS NULL 查找 NULL 值。

IS NOT NULL 运算符

IS NOT NULL 运算符用于测试非空值(NOT NULL 值)。

以下 SQL 列出了 "Address" 字段中具有值的所有客户:

实例

SELECT CustomerName, ContactName, Address
FROM Customers
WHERE Address IS NOT NULL;

亲自试一试