Oracle约束enable validate时…
来源:互联网 发布:sqlserver导出excel 编辑:程序博客网 时间:2024/05/20 05:06
Oracle约束按约束状态又可分为disable novalidate,disable validate,enablenovalidate,enable validate.其中disable/enable代表是否启用约束,validate/novalidate代表启用约束时是否对表中原有数据作检查。
这里模拟生产环境中的情况,先建一张没有约束的表,等有一定数据后建立enable novalidate约束,进而执行enablevalidate来规范表中所有数据,具体如下:
1. 创建原始表及数据
SQL> create table t1(
2
3
SQL> insert into t1 values(1,'A');
SQL> insert into t1 values(1,'B');
SQL> insert into t1 values(2,'C');
SQL> insert into t1 values(3,'D');
SQL> insert into t1 values(3,'E');
SQL> insert into t1 values(4,'F');
2. 在表上创建enable novalidate主键
SQL> alter table t1 add constraint pk_t1 primary key(id)
2
此时主键已经生效,但源表中包含不符合约束的数据
3. 尝试将约束状态更改为 enable validate,却发现原有数据有问题
SQL> alter table t1 enable validate constraintpk_t1;
alter table t1 enable validate constraint pk_t1
*
第 1 行出现错误:
ORA-02437: 无法验证 (SCOTT.PK_T1) - 违反主键
4. 找出违反约束的数据,这里采用Exceptions表保存异常数据
SQL>@%ORACLE_HOME%\RDBMS\Admin\utlexpt1.sql
SQL>alter table t1 enable validate constraintpk_t1
SQL>exceptions intoexceptions;
5. 根据异常表,找出对应源表中的异常数据
SQL> select id,name from t1 where rowid in(
2
6. 修正异常数据后,将索引生效。
备注:
启用约束:
enable( validate) :启用约束,创建索引,对已有及新加入的数据执行约束.
enable novalidate :启用约束,创建索引,仅对新加入的数据强制执行约束,而不管表中的现有数据.
禁用约束:
disable( novalidate):关闭约束,删除索引,可以对约束列的数据进行修改等操作.
disable validate :关闭约束,删除索引,不能对表进行 插入/更新/删除等操作.
0 0
- Oracle约束enable validate时…
- 利用Oracle的enable validate约束进行数据检查
- Oracle约束的关键字Enable/Disable/Validate/Novalidate
- Oracle约束的关键字Enable/Disable/Validate/Novalidate
- Oracle约束的关键字Enable/Disable/Validate/Novalidate
- Oracle约束的关键字Enable/Disable/Validate/Novalidate
- Oracle约束的关键字Enable/Disable…
- 约束disable/enable validate/novalidate 的区别
- Oracle之表示约束状态的关键字Enable/Disable/Validate/Novalidate
- Oracle 约束enable/disable novalidate
- disable/enable validate/novalidate 的区别 (ORACLE)
- oracle validate 所做的…
- oracle 约束
- Oracle PL/SQL之ENABLE NOVALIDATE约束
- Oracle定义约束 外键约束
- Oracle Constraint_type,约束类型
- Solution of Enable extension for…
- Enable/Disable/Validate/Novalidate
- Oracle ASM 详解(其二)
- Oracle ASM 详解(其三)
- Nginx+PHP-fpm 性能优化
- 详解Oracle临时表的几种用法及意义
- oracle中blob,clob,nclob,Bfile主…
- Oracle约束enable validate时…
- Oracle truncate table&…
- Oracle Index 的三个问题
- Oracle Index 介绍
- oracle各种索引使用场合及建议
- oracle索引总结
- oracle中的视图(一)
- oracle的视图(二)
- 【机房收费系统】日、周结账单