Primary key 与Unique Key都是MySQL数据库的唯一性约束。但是二者有很大的区别:
1、Primary key的1个或多个列必须为NOT NULL,如果列为NULL,在增加PRIMARY KEY时,列自动更改为NOT NULL。而UNIQUE KEY 对列没有此要求,即唯一约束的字段可以存在着空值。
2、一个表只能有一个PRIMARY KEY,但可以有多个UNIQUE KEY。
主键和唯一键约束是通过参考索引实施的,如果插入的值均为NULL,则根据索引的原理,全NULL值不被记录在索引上,所以插入全NULL值时,可以有重复的,而其他的则不能插入重复值。
例如:
alter table t add constraint uk_t_1 unique (a,b);
insert into t (a ,b ) values (null,1); # 不能重复
insert into t (a ,b ) values (null,null); # 可以重复
参考内容:http://www.w3school.com.cn/sql/sql_unique.asp