級聯truncate

12c以前的版本中,在子表引用一個主表以及子表存在記錄的狀況下,是不提供截斷此主表操做的。而在 12c 中的帶有 CASCADE 操做的TRUNCATE TABLE 能夠截斷主表中的記錄,並自動對子表進行遞歸截斷,並做爲 DELETE ON CASCADE 服從外鍵引用。因爲這是應用到全部子表的,因此對遞歸層級的數量是沒有 CAP 的,能夠是孫子表或是重孫子表等等。這一加強擯棄了要在截斷一個主表以前先截斷全部子表記錄的前提。新的 CASCADE 語句一樣也能夠應用到表分區和子表分區等。
SQL> create table parent(id number primary key);ide

Table created.code

SQL> create table child(cid number primary key,id number);遞歸

Table created.ci

SQL> insert into parent values(1);it

1 row created.table

SQL> insert into parent values(2);class

1 row created.select

SQL> insert into child values(1,1);引用

1 row created.im

SQL> insert into child values(2,1);

1 row created.

SQL> insert into child values(3,2);

1 row created.

SQL> commit;

Commit complete.

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

ID        CID         ID

1          1          1
     1          2          1
     2          3          2

--添加約束,不附上 on delete cascade
SQL> alter table child add constraint fk_parent_child foreign key(id) references parent(id);

Table altered.

SQL> truncate table parent cascade;
truncate table parent cascade
*
ERROR at line 1:
ORA-14705: unique or primary keys referenced by enabled foreign keys in table
"HR"."CHILD"

SQL> col CONSTRAINT_NAME for a25;
SQL> col TABLE_NAME for a25;
SQL> col COLUMN_NAME for a25;
SQL> select CONSTRAINT_NAME,TABLE_NAME, COLUMN_NAME from user_cons_columns where TABLE_NAME='CHILD';

CONSTRAINT_NAME TABLE_NAME COLUMN_NAME


SYS_C0010458 CHILD CID
FK_PARENT_CHILD CHILD ID
-- 刪除並添加約束,並附上 on delete cascade
SQL> alter table child drop constraint FK_PARENT_CHILD;

Table altered.

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.

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

no rows selected

相關文章
相關標籤/搜索