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

<b>小议Oracle外键约束修转业为(一)-PLSQL</b>[Oracle防范]

赞助商链接



  本文“<b>小议Oracle外键约束修转业为(一)-PLSQL</b>[Oracle防范]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:

    Oracle的外键用来限制子表中参考的字段的值,必须在主表中存在.并且在主表的记录发生改变招致外键参考唯一约束值发生了改变时,定义了一系列的行动.

    在SQL92尺度中定义了几种外键改变后,若何处理子表记录的行动,此中包含:

    限制Restrict:这种方法不答应对被参考的记录的键值履行更新或删除的操作;置为空Set to null:当参考的数据被更新大概删除,那么全部参考它的外键值被置为空;

    置为默许值Set to default:当参考的数据被更新大概删除,那么全部参考它的外键值被置为一个默许值;

    级联Cascade:当参考的数据被更新,则参考它的值一样被更新,当参考的数据被删除,则参考它的子表记录也被删除;

    不做操作No action:这种方法不答应更新或删除被参考的数据.和限制方法的辨别在于,这种方法的查抄发生在语句履行之后.Oracle默许才会的方法就是这种方法.

    Oracle明确支持的方法包含No action、Set to null和Cascade.关于Set to Default和Restrict,Oracle的约束范例并不直接支持,不过可以通过触发器来实现.

    简单看一下Oracle的默许处理方法No action:

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);

表已更改.

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> COMMIT;

提交完成.

关于No Action操作而言,假如主键的记录被外键所参考,那么主键记录是无法更新或删除的.

SQL> DELETE T_P WHERE ID = 1;
DELETE T_P WHERE ID = 1
*
1 行呈现错误:
ORA-02292:
违反完好约束条件 (YANGTK.FK_T_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) - 已找到子记录日记


SQL> DELETE T_P WHERE ID = 2;

已删除 1 行.

不过No Action又和Restrict操作有所辨别,No Action答应用户履行语句,在语句履行之后,大概事件完毕的时刻才会查抄能否违反约束.而Restrict只有检测到有外键参考主表的记录,就不答应删除和更新的操作履行了.

这也使得No Action操作支持耽误约束:

SQL> ALTER TABLE T_C DROP CONSTRAINT FK_T_C;

表已更改.

SQL> ALTER TABLE T_C ADD CONSTRAINT FK_T_C
2 FOREIGN KEY (FID)
3 REFERENCES T_P (ID)
4 DEFERRABLE INITIALLY DEFERRED;

表已更改.

SQL> SELECT * FROM T_P;

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

SQL> SELECT * FROM T_C;

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

SQL> DELETE T_P WHERE ID = 1;

已删除 1 行.

SQL> INSERT INTO T_P VALUES (1, 'A');

已成立 1 行.

SQL> COMMIT;

提交完成.

  以上是“<b>小议Oracle外键约束修转业为(一)-PLSQL</b>[Oracle防范]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • <b>hosts是什么 hosts文件在什么位置 若何改正hosts</b>
  • <b>在 Windows 8 中手动安装语言包</b>
  • <b>五个常见 PHP数据库问题</b>
  • Windows中Alt键的12个高效快速的利用本领介绍
  • <b>MySQL ORDER BY 的实现解析</b>
  • <b>详解MySQL存储历程参数有三种范例(in、out、inout)</b>
  • <b>Win8系统恢复出来经典的开始菜单的办法</b>
  • <b>Win8系统花屏怎么办 Win8系统花屏的办理办法</b>
  • <b>Windows 7系统下无线网卡安装</b>
  • <b>为什么 Linux不需求碎片整理</b>
  • <b>Windows 8中删除账户的几种办法(图)</b>
  • <b>教你如安在win7下配置路由器</b>
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

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

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