MySQL:UNIQUE,但DEFAULT NULL - 通过创建表允许.允许插入超过1个NULL.为什么?

Har*_*iec 7 mysql null default unique

我刚刚检查过并且允许创建一个默认为NULL的表,尽管它同时是一个独特的键:

CREATE TABLE IF NOT EXISTS `u789` (
`column1` varchar(10) DEFAULT NULL,
UNIQUE KEY (column1)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
Run Code Online (Sandbox Code Playgroud)

据我所知,它看起来很奇怪,没有多大意义.我期待第二次插入

INSERT INTO u789 VALUE (NULL);
Run Code Online (Sandbox Code Playgroud)

将失败.

但是,它会毫无问题地插入第一个,第二个,第三个NULL值.如果表格中已经有NULL,谁可以解释为什么它是第二列和第三列?

这是一个理论问题(据我所知,在大多数情况下,没有人使用DEFAULT NULL + UNIQUE KEY作为同一列),但我想理解为什么一旦NULL已经在列中,它就不会抛出错误.我在声明一个独特的列时做错了吗?

谢谢.

Tho*_*mas 22

根据SQL 92规范(以及您如何阅读它),唯一约束用于表示候选键,因此不应允许重复值 NULL值.DB2以这种方式实现其唯一约束.不止一些数据库供应商(包括MySQL)将规范读取为忽略NULL值,就像Group By子句忽略NULL值一样,因此它们实现了唯一约束,使得它仅适用于非NULL值.还有一些,将NULL视为自己的特殊值,只允许一个NULL项.Microsoft SQL Server以这种方式实现了唯一的约束.所有供应商在唯一约束方面唯一一致的方面是非NULL值必须是唯一的.


a1e*_*x07 6

因为NULL不等于NULL.即使某些RDMS,例如SQLServer,NULL在涉及唯一约束时也将2 s视为相等.