执行truncate触发ORA-02266解决过程是怎样的

技术执行truncate触发ORA-02266解决过程是怎样的这篇文章给大家介绍执行truncate触发ORA-02266解决过程是怎样的,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。开发提了个需求

本文向您介绍截断触发器ORA-02266解决方案过程的实现。内容非常详细,有兴趣的朋友可以参考一下,希望对你有帮助。

开发了一个需求来清除测试数据库的数据,这涉及到主表和次表之间的关系,如下所示。

执行truncate触发ORA-02266解决过程是怎样的

最直观的方法是截断表。首先截断每个子表,但是当执行截断主表时,会提示一个错误,ORA-022663360表中的唯一/主键被启用的外键引用。

子表目前没有数据。为什么不删除主表的数据?

让我们模拟一下这个过程。首先,我们创建测试表,主表a_1和子表b_1。

SQL创建表a_1 (id号);

表已创建。

SQL创建表b_1 (id号,id_a_1号);

表已创建。

SQL alter table a_1添加约束pk_a_1主键(id);

桌子变了。

SQL alter table b_1添加约束fk_b_a外键(id_a_1)引用a _ 1(id);

桌子变了。

此时,截断子表和主表将会成功。

SQL截断表b _ 01

表格被截断。

SQL截断表a _ 01

表格被截断。

但是当主子表和截断子表中都有数据时,截断主表的操作会提示ORA-02266的错误。

SQL插入a_1值(1);

已创建1行。

SQL插入b_1值(1,1);

已创建1行。

SQL提交;

提交完成。

SQL截断表b _ 1;

表格被截断。

SQL截断表a _ 1;

截断表a_1

*

第1:行出错

ORA-02266:启用的外键引用的表中的唯一/主键

ORA-02262的错误含义是“表中启用了唯一/主键的外键引用”,

02262,00000,'对列默认值表达式进行类型检查时出现ORA-%s '

//*原因:新的列数据类型导致现有列的类型检查错误

//默认值表达式。

//*操作:删除默认值表达式或不更改列

//数据类型。

但是子表中没有数据。为什么主表还是提示这个错误?原因与截断操作有关,因为截断是DDL,但是DDL语句不会检查约束,换句话说,他不知道子表数据是否依赖于他,所以他根本不会去做。

但是,当主表和辅助表中没有数据时,截断主表能否成功是有疑问的,截断主表只会在主表和辅助表中有数据时才会提示。我看了统计数据。表中没有数量记录。Oracle如何知道当前表中有数据并禁止截断?

p>

我猜测,可能是延迟段的影响?

1. 看下表中有数据,执行truncate产生的10046,其中truncate table a_1主表时,有个绑定变量的参数是B_1,推测由此知道a_1有外键引用,进而报错,err=2266

...
LOCK TABLE "A_1" IN EXCLUSIVE MODE  NOWAIT
...
truncate table a_1
...
Bind#1
  oacdty=01 mxl=32(03) mxlc=00 mal=00 scl=00 pre=00
  oacflg=10 fl2=0001 frm=01 csi=873 siz=0 off=24
  kxsbbbfp=7f2df926afc8  bln=32  avl=03  flg=01
  value="B_1"
...
ERROR #139835430202688:err=2266 tim=1562853681567125
...

2. 看下表中无数据,执行truncate产生的10046,发现他会检索deferred_stg$视图,truncate是靠aw_trunc_proc存储过程

...
LOCK TABLE "A_1" IN EXCLUSIVE MODE  NOWAIT
...
select pctfree_stg, pctused_stg, size_stg,initial_stg, next_stg, minext_stg, maxext_stg, maxsiz_stg, lobret_stg,mintim_stg, pctinc_stg, initra_stg, maxtra_stg, optimal_stg, maxins_stg,frlins_stg, flags_stg, bfp_stg, enc_stg, cmpflag_stg, cmplvl_stg from deferred_stg$ where obj# =:1
...
truncate table a_1
...
BEGIN
  aw_trunc_proc(ora_dict_obj_type, ora_dict_obj_name, ora_dict_obj_owner);
END;
...

3. 关闭session级别的延迟段特性

gment_creation=false;

Session altered.

表中无数据,执行truncate产生的10046,和上面两个比,操作最简单,LOCK表,执行truncate,没其他操作了

...
LOCK TABLE "A_1" IN EXCLUSIVE MODE  NOWAIT
...
truncate table a_1
...

从现象看,不是延迟段特性,导致两者的区别,需要请大佬指教。

针对ORA-02266的错误,有几种解决方案,

方案1:禁用约束-truncate-启用约束
可以参考MOS这篇文章《OERR: ORA-2266 "unique/primary keys in table referenced by enabled foreign keys" Reference Note (Doc ID 19499.1)》。

1. 找出主表的约束

SELECT constraint_name
FROM user_constraints
WHERE table_name = '<table_you_are_trying_to_drop>'
AND constraint_type = 'P';

SELECT *
FROM user_constraints
WHERE constraint_type = 'R'
AND r_constraint_name = '<constraint_name_returned_above>';

或者执行下列任意一个SQL,都可以得到主键相关的外键参考

select a.constraint_type,a.table_name,a.status, b.table_name,b.column_name,b.constraint_name from user_constraints a
inner join user_cons_columns b on a.constraint_name = b.constraint_name
where a.r_constraint_name='主键约束名称';

select c.TABLE_NAME
from all_constraints p, all_constraints c
where p.table_name = '主键约束名称'
and p.OWNER = SYS_CONTEXT('USERENV', 'CURRENT_SCHEMA')
and c.OWNER=SYS_CONTEXT('USERENV', 'CURRENT_SCHEMA')
and c.constraint_type = 'R'
and p.CONSTRAINT_NAME = c.R_CONSTRAINT_NAME;

2. 删除约束

SQL> alter table a_1 disable primary key cascade;
Table altered.

3. 执行truncate

4. 启用约束

只是需要注意,enable恢复主键的操作,并不会自动enable外键,需要手工enable外键

SQL> alter table tbl_a enable primary key;
Table altered.

SQL> alter table tbl_b enable constraint fk_b_a;
Table altered.

方案2:delete删除
使用delete,DML操作是可以正常删除主表,只是不适合数据量很大的场景。

关于执行truncate触发ORA-02266解决过程是怎样的就分享到这里了,希望

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/138392.html

(0)

相关推荐

  • iphone手机壁纸,苹果手机壁纸在哪里可以找到

    技术iphone手机壁纸,苹果手机壁纸在哪里可以找到1、解锁iPhoneiphone手机壁纸,然后找到设置,点击设置、墙纸。2、点击选取新的墙纸,能看到所有系统的壁纸。一、手机壁纸通常也被称之为手机图片,待机图片,就跟W

    生活 2021年10月28日
  • 含卧字的成语典故,卧字的成语典故是什么主人公是

    技术含卧字的成语典故,卧字的成语典故是什么主人公是典故含卧字的成语典故:春秋时期,吴越两邻国,经常打仗,有次吴王领兵攻打越国,被越王勾践的大将砍中了右脚,最后伤重而亡。吴王死后,他的儿子夫差继位。三年以后,夫差带兵前去攻

    生活 2021年10月29日
  • worst,worst是bad的最高级吗

    技术worst,worst是bad的最高级吗bad在早期现代英语时变比较级和最高级是符合规则的,后来“badder”和“baddest”才被完全被另外两个词代替掉worst。 Worse和worst确实是比较级和最高级的

    生活 2021年10月30日
  • C++ 串口通信时字符串转16进制转换

    技术C++ 串口通信时字符串转16进制转换 C++ 串口通信时字符串转16进制转换//************************************
    // Method: strToHe

    礼包 2021年10月19日
  • 抖音刷人气平台,刷赞的网站是什么原理

    技术抖音刷人气平台,刷赞的网站是什么原理这个抖音点赞不赚钱,网红赚的都是粉丝刷的礼物,还有网红粉丝数,只有这两种情况才赚钱。爱能让抖音直播主播人气上升,代表人气值,爱越多,证明主播人气越高。爱却无法换来金钱,只有礼物可以

    测评 2021年10月20日
  • 端口扫描工具Pscan怎么用

    技术端口扫描工具Pscan怎么用这期内容当中小编将会给大家带来有关端口扫描工具Pscan怎么用,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。今天给大家介绍一款端口扫描工具Pscan一、

    2021年12月10日