oracle truncte 级联,Oracle 12C 新特性之级联truncate

本文介绍了12c Oracle数据库中新增的CASCADE操作,允许在TRUNCATETABLE时自动递归删除子表记录,简化了主表与子表之间的依赖管理,不再需要预先处理子表。详细演示了如何在不同约束条件下使用这一特性。
摘要由CSDN通过智能技术生成

12c之前的版本中,在子表引用一个主表以及子表存在记录的情况下,是不提供截断此主表操作的。而在 12c 中的带有 CASCADE 操作的TRUNCATE TABLE 可以截断主表中的记录,并自动对子表进行递归截断,并作为 DELETE ON CASCADE 服从外键引用。由于这是应用到所有子表的,所以对递归层级的数量是没有 CAP 的,可以是孙子表或是重孙子表等等。这一增强摈弃了要在截断一个主表之前先截断所有子表记录的前提。新的 CASCADE 语句同样也可以应用到表分区和子表分区等。

SQL>

create table parent(id number primary key);

create table child(cid number primary key,id number);

insert into parent values(1);

insert into parent values(2);

insert into child values(1,1);

insert into child values(2,1);

insert into child values(3,2);

commit;

SQL> select a.id,b.cid,b.id from parent a, child b where a.id=b.id;

IDCIDID

---------- ---------- ----------

111

121

232

--添加约束,不附上 on delete cascade

SQL> alter table child add constraint fk_parent_child foreign key(id) references parent(id);

SQL> truncate table parent cascade;

ERROR at line 1:

ORA-14705: unique or primary keys referenced by enabled foreign keys in table

"C##ANDY"."CHILD"

-- 查看表约束

SQL>

col CONSTRAINT_NAME for a25;

col TABLE_NAME for a25;

col COLUMN_NAME for a25;

select CONSTRAINT_NAME,TABLE_NAME, COLUMN_NAME from user_cons_columns where TABLE_NAME='CHILD';

CONSTRAINT_NAME           TABLE_NAME                COLUMN_NAME

------------------------- ------------------------- -------------------------

SYS_C007353               CHILD                     CID

FK_PARENT_CHILD           CHILD                     ID

-- 删除约束

SQL> alter table child drop constraint FK_PARENT_CHILD;

Table altered.

-- 添加约束,并附上 on delete cascade

SQL> alter table child add constraint fk2_parent_child foreign key(id) references parent(id) on delete cascade;

Table altered.

SQL> truncate table parent cascade;

Table truncated.

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值