NULL 和唯一约束 UNIQUE 的对应关系
在数据库中,NULL表示列值为空。唯一约束 UNIQUE 规定指定列的值必须是唯一的,值和值之间都不能相同。这个时候,就出现一个问题,NULL 和 NULL 算是相同,还是不同。由于 SQL 语法没有明确规定,所以各个数据库厂商的处理方式不同。
(1)PostgreSQL 和 Oracle 认为 NULL 表示没有指定数据,所以数据有多种可能,所以 UNIQUE 约束列中允许存在任意多个 NULL。
(2)Informix 和 SQL Server 认为 NULL 就表示空,是一种唯一的状态。所以 UNIQUE 约束列中只能有一个 NULL。
(3)DB2、SQLAnyWhere 和 InterBase 认为 NULL 存在不确定性,无法比较,所以 UNIQUE 约束列中不允许有 NULL。
而 SQLite 遵循了 PostgreSQL 和 Oracle 的策略,允许 UNIQUE 约束列中有任意个 NULL。