NULL
值是用于表示 SQL 中缺失数据的特殊值。任何类型的列都可以包含 NULL
值。从逻辑上讲,NULL
值可以被视为“此字段的值未知”。
一个NULL
值可以被插入到任何没有NOT NULL
限定符的字段中:
CREATE TABLE integers (i INTEGER);
INSERT INTO integers VALUES (NULL);
NULL
值在查询的许多部分以及许多函数中具有特殊的语义:
任何与
NULL
值的比较都会返回NULL
,包括NULL = NULL
。
你可以使用IS NOT DISTINCT FROM
来执行一个相等比较,其中NULL
值相互比较时被认为是相等的。使用IS (NOT) NULL
来检查一个值是否为NULL
。
SELECT NULL = NULL;
NULL
SELECT NULL IS NOT DISTINCT FROM NULL;
true
SELECT NULL IS NULL;
true
NULL 和函数
一个以NULL
作为输入参数的函数通常会返回NULL
。
SELECT cos(NULL);
NULL
coalesce
函数是一个例外:它接受任意数量的参数,并为每一行返回第一个不为 NULL
的参数。如果所有参数都是 NULL
,coalesce
也会返回 NULL
。
SELECT coalesce(NULL, NULL, 1);
1
SELECT coalesce(10, 20);
10
SELECT coalesce(NULL, NULL);
NULL
ifnull
函数是 coalesce
的一个双参数版本。
SELECT ifnull(NULL, 'default_string');
default_string
SELECT ifnull(1, 'default_string');
1
NULL
和连接词
NULL
值在 AND
/OR
连接中有特殊的语义。关于三元逻辑真值表,请参阅 Boolean Type documentation。
NULL
和聚合函数
NULL
值在大多数聚合函数中被忽略。
不忽略NULL
值的聚合函数包括:first
、last
、list
和array_agg
。要从这些聚合函数中排除NULL
值,可以使用FILTER
子句。
CREATE TABLE integers (i INTEGER);
INSERT INTO integers VALUES (1), (10), (NULL);
SELECT min(i) FROM integers;
1
SELECT max(i) FROM integers;
10