当前位置:七道奇文章资讯数据防范Oracle防范
日期:2011-01-25 22:55:00  来源:本站整理

小议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
2 FOREIGN KEY (FID)
3 REFERENCES T_P (ID)
4 ON DELETE CASCADE;

表已更改.

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
---------- ------------------------------
1 A
2 B

SQL> SELECT * FROM T_C;

ID FID NAME
---------- ---------- ------------------------------
1 1 A
2 2 B
3 1 C

SQL> DELETE T_P WHERE ID = 2;

已删除 1 行.

SQL> SELECT * FROM T_C;

ID FID NAME
---------- ---------- ------------------------------
1 1 A
3 1 C

SQL> UPDATE T_P SET ID = 3 WHERE ID = 1;
UPDATE T_P SET ID = 3 WHERE ID = 1
*
1 行呈现错误:
ORA-02292:
违反完好约束条件 (YANGTK.FK_T_C) - 已找到子记录日记

可以看到,和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,
2 CONSTRAINT FK_T_C_C FOREIGN KEY (FID) REFERENCES T_C(ID) ON DELETE CASCADE);

表已成立.

SQL> INSERT INTO T_C_C VALUES (1, 1);

已成立 1 行.

SQL> CREATE TABLE T_C_C_C (ID NUMBER PRIMARY KEY, FID NUMBER,
2 CONSTRAINT FK_T_C_C_C FOREIGN KEY (FID) REFERENCES T_C_C(ID) ON DELETE CASCADE);

表已成立.

SQL> INSERT INTO T_C_C_C VALUES (1, 1);

已成立 1 行.

SQL> COMMIT;

提交完成.

下面看看级联删除的效果:

SQL> SELECT * FROM T_P;

ID NAME
---------- ------------------------------
1 A

SQL> SELECT * FROM T_C;

ID FID NAME
---------- ---------- ------------------------------
1 1 A
3 1 C

SQL> SELECT * FROM T_C_C;

ID FID
---------- ----------
1 1

SQL> SELECT * FROM T_C_C_C;

ID FID
---------- ----------
1 1

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防范]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • 小议Oracle外键约束修转业为(五)-PLSQL
  • <b>小议Oracle外键约束修转业为(四)-PLSQL</b>
  • 小议Oracle外键约束修转业为(六)-PLSQL
  • 小议Oracle外键约束修转业为(七)-PLSQL
  • <b>小议Oracle外键约束修转业为(一)-PLSQL</b>
  • 小议Oracle外键约束修转业为(二)-PLSQL
  • 小议Oracle外键约束修转业为(三)-PLSQL
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .