表中已存重复数据的情况,如何增加唯一性约束


1.oracle 官网给出建议:
如果约束设置enable,则会检查新插入或更新的数据是否符合约束条件。

如果约束设置disable,则表中可以包含,违反约束的记录。

如果约束设置validate,则表中存在的数据,必须符合约束。

如果约束设置novalidate,则表中存在的数据,不必符合约束。

validate和novalidate的行为,依赖于是否设置了enabled/disabled。 因此创建约束的时候,可以选择组合方式来达到目的。

2.针对表中已存在重复数据且要增加唯一约束的情况:
a.直接创建唯一约束,仍报错,是因为数据库会根据唯一约束创建唯一索引,因此报错;
alter table table_name add constraint constraint_name unique(colunum) enable novalidate;

b.此时应该先创建普通索引,然后在此基础上创建唯一约束:
create index idx_name on table_name(colunum);
alter table table_name add constraint constraint_name unique(colunum) enable novalidate;

 

同理:也可以根据此方法创建唯一主键

create index idx_name on table_name(colunum);

alter table tablename add constraint pk_tablename primary key (column1,column2,...) enable novalidate;

上一篇:1452, 'Cannot add or update a child row: a foreign key constraint fails


下一篇:sqlsrver-常见英语单词释意