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

本文介绍了在SQL中如何处理已有重复数据的列,并添加唯一约束。当尝试在已有重复值的列上创建唯一约束时,会遇到错误。一种解决方法是先创建索引,然后使用`ALTER TABLE`语句添加唯一约束并启用约束,但不验证现有数据,这样就能确保新插入的数据符合唯一性要求,而不会影响到已存在的重复数据。
摘要由CSDN通过智能技术生成

在有重复数据的列上添加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 ——–

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值