小议Oracle外键约束修转业为(七)-PLSQL[Oracle防范]
本文“小议Oracle外键约束修转业为(七)-PLSQL[Oracle防范]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
Oracle的外键用来限制子表中参考的字段的值,必须在主表中存在.并且在主表的记录发生改变招致外键参考唯一约束值发生了改变时,定义了一系列的行动.
这篇描写一下若何实现RESTRICT.
前面几篇文章介绍了Oracle所支持的3种约束行为NO ACTION、DELETE SET NULL和DELETE CASCADE.
至于SQL尺度中定义的其他操作,Oracle只能通过触发器来实现,这里给出一个简单的RESTRICT操作的例子.
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> COMMIT; 提交完成. SQL尺度定义的RESTRICT操作其实和NO ACTION操作非常近似.差别之处在于,RESTRICT的查抄在语句履行之前,一旦发现主键被引用,就会报错,禁止更新或删除操作的履行. SQL> SELECT * FROM T_P; ID NAME SQL> SELECT * FROM T_C; ID FID NAME SQL> UPDATE T_P SET ID = 3 WHERE ID = 1; 关于上面这种情形,无论是NO ACTION还是RESTRICT,效果没有什么差别,而关于下面的情形就不一样了: SQL> UPDATE T_P SET ID = ID - 1; 已更新2行. SQL> SELECT * FROM T_P; ID NAME SQL> UPDATE T_P SET ID = ID + 1; 已更新2行. SQL> SELECT * FROM T_P; ID NAME 关于NO ACTION来说,约束的查抄发生在语句之后,全部上面的语句可以顺利履行,而关于RESTRICT而言,这个操作会直接报错. 下面构建一个RESTRICT操作的触发器: SQL> CREATE OR REPLACE TRIGGER T_P_RESTRICT 触发器已成立 SQL> SELECT * FROM T_P; ID NAME SQL> SELECT * FROM T_C; ID FID NAME SQL> UPDATE T_P SET ID = ID - 1; 这种方法可以实现RESTRICT操作,但是关于其他会话的外键的引用,RESTRICT操作是看不到的: SQL> CONN YANGTK/YANGTK@YTK92已衔接. 已成立 1 行. 在另一个会话插入一条参考主表ID为2的记录,且不提交,这时在主表更新或删除ID为2的记录时,会被锁住,RESTRICT操作不会起作用,因为这时看不到其他用户未提交的改正: SQL> DELETE T_P WHERE ID = 2; 而假如在第二个会话中提交事件: SQL2> COMMIT; 提交完成. 则RESTRICT操作会起作用,因为这时已经提交,而当前的会话是可以看到其他会话中已提交数据的: DELETE T_P WHERE ID = 2
|
以上是“小议Oracle外键约束修转业为(七)-PLSQL[Oracle防范]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |