SQL Null Values

创建于 2024-12-02 / 34
字体: [默认] [大] [更大]

什么是 NULL 值?

具有 NULL 空值的字段表示此字段没有值。

如果表中的某个列是可选的,那么我们可以在不向该列添加值的情况下插入新记录或更新已有的记录。这意味着该字段将以 NULL 值保存。

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


如何测试空值?

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

我们将使用 IS NULL 和 IS 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;

演示数据库

以下是从 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


IS NULL

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

以下 SQL 列出了 地址(Address) 字段中具有空值的所有客户:

实例

SELECT CustomerName, ContactName, Address
FROM Customers
WHERE Address IS NULL; 亲自试一试 »

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


IS NOT NULL

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

以下 SQL 列出了 地址(Address) 字段中有值的所有客户:

实例

SELECT CustomerName, ContactName, Address
FROM Customers
WHERE Address IS NOT NULL; 亲自试一试 »

学习训练

练习题:

Customers 中选择所有记录,其中 PostalCode 列为空。

SELECT * FROM Customers
WHERE   ;

Start the Exercise



0 人点赞过