小议Oracle外键约束修转业为(三)-PLSQL[Oracle防范]
本文“小议Oracle外键约束修转业为(三)-PLSQL[Oracle防范]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
Oracle的外键用来限制子表中参考的字段的值,必须在主表中存在.并且在主表的记录发生改变招致外键参考唯一约束值发生了改变时,定义了一系列的行动.
这篇简单描写一下CASCADE操作.
上一篇描写了Oracle外键处理操作:SET TO NULL,这里简单介绍一下CASCADE操作.还是操纵前面例子的表,不过约束需求重建.
SQL> DROP TABLE T_C; 表已删除. SQL> DROP TABLE T_P; 表已删除. SQL> CREATE TABLE T_P (ID NUMBER, NAME VARCHAR2(30)); 表已成立. SQL> ALTER TABLE T_P ADD PRIMARY KEY (ID); 表已更改. SQL> CREATE TABLE T_C (ID NUMBER, FID NUMBER, NAME VARCHAR2(30)); 表已成立. SQL> ALTER TABLE T_C ADD CONSTRAINT FK_T_C 表已更改. SQL> INSERT INTO T_P VALUES (1, 'A'); 已成立 1 行. SQL> INSERT INTO T_P VALUES (2, 'B'); 已成立 1 行. SQL> INSERT INTO T_C VALUES (1, 1, 'A'); 已成立 1 行. SQL> INSERT INTO T_C VALUES (2, 2, 'B'); 已成立 1 行. SQL> INSERT INTO T_C VALUES (3, 1, 'C'); 已成立 1 行. SQL> COMMIT; 提交完成. 下面看看CASCADE是若何工作的: SQL> SELECT * FROM T_P; ID NAME SQL> SELECT * FROM T_C; ID FID NAME SQL> DELETE T_P WHERE ID = 2; 已删除 1 行. SQL> SELECT * FROM T_C; ID FID NAME SQL> UPDATE T_P SET ID = 3 WHERE ID = 1; 可以看到,和SET TO NULL约束一样,CASCADE操作也是只对DELETE语句有效,而关于UPDATE语句不起作用. 别的提一句,和SET TO NULL差别,CASCADE具有传送性,主表删除一条记录,会招致子表参考的记录被删除,而子表的记录被删除又会招致子表的子表记录被删除: SQL> ALTER TABLE T_C ADD PRIMARY KEY (ID); 表已更改. SQL> CREATE TABLE T_C_C (ID NUMBER PRIMARY KEY, FID NUMBER, 表已成立. SQL> INSERT INTO T_C_C VALUES (1, 1); 已成立 1 行. SQL> CREATE TABLE T_C_C_C (ID NUMBER PRIMARY KEY, FID NUMBER, 表已成立. SQL> INSERT INTO T_C_C_C VALUES (1, 1); 已成立 1 行. SQL> COMMIT; 提交完成. 下面看看级联删除的效果: SQL> SELECT * FROM T_P; ID NAME SQL> SELECT * FROM T_C; ID FID NAME SQL> SELECT * FROM T_C_C; ID FID SQL> SELECT * FROM T_C_C_C; ID FID SQL> DELETE T_P; 已删除 1 行. SQL> SELECT * FROM T_P; 未选定行 SQL> SELECT * FROM T_C; 未选定行 SQL> SELECT * FROM T_C_C; 未选定行 SQL> SELECT * FROM T_C_C_C; 未选定行 |
以上是“小议Oracle外键约束修转业为(三)-PLSQL[Oracle防范]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |