>데이터 베이스 >MySQL 튜토리얼 >oracle在已有重复数据的列上创建唯一约束

oracle在已有重复数据的列上创建唯一约束

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB원래의
2016-06-07 15:07:271702검색

在有重复数据的列上添加unique constraints,大家正常的解决办法就修改重复数据,但也可以 保留重复数据,使约束对以后的数据有限制,不过我们还可以用以下的方法来添加唯一约束. SQL create table aa(num number(6),email varchar2(32)); 表已创建。 SQL insert

在有重复数据的列上添加unique constraints,大家正常的解决办法就修改重复数据,但也可以

保留重复数据,使约束对以后的数据有限制,不过我们还可以用以下的方法来添加唯一约束.

SQL> create table aa(num number(6),email varchar2(32));

表已创建。

SQL> insert into aa values(1,'11');

已创建 1 行。

SQL> insert into aa values(2,'11');

已创建 1 行。

SQL> commit;

提交完成。

SQL> alter table aa add constraint aa_un unique(email) ;
alter table aa add constraint aa_un unique(email)
                              *
第 1 行出现错误:
ORA-02299: 无法验证 (PERFSTAT.AA_UN) - 找到重复关键字


SQL> create index aa_inx on aa(email);

索引已创建。

SQL> alter table aa add constraint aa_un unique(email) enable novalidate;

表已更改。

SQL> commit;

提交完成。

SQL> insert into aa values(1,'11');
insert into aa values(1,'11')
*
第 1 行出现错误:
ORA-00001: 违反唯一约束条件 (PERFSTAT.AA_UN)


SQL>


----- end --------


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.