根据NULL的定义,NULL表⽰的是未知,因此两个NULL⽐较的结果既不相等,也不不等,结果仍然是未知。根据这个定义,多个NULL值的存在应该不违反唯⼀约束。
CREATE TABLE TESTAA (ID NUMBER)SELECT * FROM TESTAA;
ALTER TABLE TESTAA ADD UNIQUE (ID);INSERT INTO TESTAA VALUES (NULL);单个值NULL可以随意插⼊进去,不报错。
但是当唯⼀约束为复合字段时,则情况发⽣了变化。根据Oracle⽂档的描述,对于复合字段的唯⼀约束,不为空字段的值是不能重复的。也就是说,如果两个字段构成了⼀个唯⼀约束,其中⼀个字段为空,那么另⼀个字段的值不能出现重复。CREATE TABLE test1(id NUMBER,id2 NUMBER);
ALTER TABLE test1 add UNIQUE(id, id2);INSERT INTO test1 VALUES (1,1);INSERT INTO test1VALUES (NULL,NULL);如果插⼊两次如下的记录,会报错,违反唯⼀性。INSERT INTO test1 VALUES(1,NULL);
全部为NULL的情况,仍然和单字段唯⼀约束⼀样,不会造成重复,但是对于部分为NULL的情况,就如上⾯例⼦所⽰,只要其中不为NULL的部分发⽣了重复,Oracle就认为约束发⽣了重复。原因如下:
由于Oracle的唯⼀约束是依赖索引实现的,⽽Oracle的BTREE索引⼜是不存储NULL值的,所以键值全部为NULL的记录不会记录在索引中,因此也就不会违反唯⼀约束了,⽽对于部分为NULL的记录,索引是要记录数值的,因此⼀旦键值中⾮NULL部分发⽣了冲突,Oracle就认为违反了的唯⼀约束。
因篇幅问题不能全部显示,请点此查看更多更全内容