oracle系列--级联删除和级联更新

必须声明:此博客转载于Oracle外键级联删除和级联更新http://www.2cto.com/database/201507/417496.html

鉴于此前收藏的精彩博客无料被删除了,很是痛心,所以还是要复制一下

一、级联删除

Oracle在外键的删除上有NO ACTION(类似RESTRICT)、CASCADE和SET NULL三种行为。

下面以学生-班级为例说明不同情况下的外键删除,学生属于班级,班级的主键是学生的外键。

 1 -- 班级表
 2 CRATE TABLE TB_CLASS
 3 (
 4   ID    NUMBER NOT NULL, --班级主键
 5   NAME  VARCHAR2(50), --班级名称
 6   CONSTRAINT PK_TB_CLASS PRIMARY KEY (ID)
 7 );
 8
 9 -- 学生表
10 CREATE TABLE TB_STUDENT
11 (
12   ID        NUMBER NOT NULL,   --学生主键
13   NAME      VARCHAR2(50),      --学生姓名
14   CLASS_ID  NUMBER,            --学生所属班级,外键
15
16   --主键约束
17   CONSTRAINT PK_TB_STUDENT PRIMARY KEY (ID),
18
19   --外键约束
20   --设置级联删除为NO ACTION
21   CONSTRAINT FK_TB_STUDENT_CLASS_ID FOREIGN KEY (CLASS_ID) REFERENCES TB_CLASS (ID)
22 );
23
24 -- 添加班级数据
25 INSERT INTO TB_CLASS (ID, NAME) VALUES (1, ‘一班‘);
26 INSERT INTO TB_CLASS (ID, NAME) VALUES (2, ‘二班‘);
27 INSERT INTO TB_CLASS (ID, NAME) VALUES (3, ‘三班‘);
28
29 -- 添加学生数据
30 INSERT INTO TB_STUDENT (ID, NAME, CLASS_ID) VALUES (1, ‘小明‘, 1);
31 INSERT INTO TB_STUDENT (ID, NAME, CLASS_ID) VALUES (2, ‘小刚‘, 1);
32 INSERT INTO TB_STUDENT (ID, NAME, CLASS_ID) VALUES (3, ‘小王‘, 1);
33 INSERT INTO TB_STUDENT (ID, NAME, CLASS_ID) VALUES (4, ‘二明‘, 2);
34 INSERT INTO TB_STUDENT (ID, NAME, CLASS_ID) VALUES (5, ‘二刚‘, 2);
35 INSERT INTO TB_STUDENT (ID, NAME, CLASS_ID) VALUES (6, ‘二王‘, 2);
36 INSERT INTO TB_STUDENT (ID, NAME, CLASS_ID) VALUES (7, ‘大明‘, 3);
37 INSERT INTO TB_STUDENT (ID, NAME, CLASS_ID) VALUES (8, ‘大刚‘, 3);
38 INSERT INTO TB_STUDENT (ID, NAME, CLASS_ID) VALUES (9, ‘大王‘, 3);

1、NO ACTION

NO ACTION指当删除主表中被引用列的数据时,如果子表的引用列中包含该值,则禁止该操作执行。

现在学生外键级联删除是NO ACTION,执行删除班级操作。

2、SET NULL

SET NULL指当删除主表中被引用列的数据时,将子表中相应引用列的值设置为NULL值。SET NULL有个前提就是外键引用列必须可以设置为NULL。

把学生表(TB_STUDENT)的外键删除行为改为SET NULL。ORACLE似乎没有MODIFY CONSTRAINT操作,只能先删除外键,然后创建新的。

3、CASCADE

CASCADE指当删除主表中被引用列的数据时,级联删除子表中相应的数据行。

把学生表(TB_STUDENT)的外键删除行为改为CASCADE。

二、级联更新

Oracle本身并不支持外键的级联更新,不过可以按照如下方法达到级联更新的效果。

首先要先了解Oracle延迟约束和非延迟约束。非延迟约束就是在修改记录的时候会立刻进行约束条件的查看,是否因为违反了某些约束条件而不能执行修改。延迟约束不会在刚进行修改的时候进行约束查看,只有提交的时候才会检查。Oracle的级联更新就是使用这个特性来实现的。

Oracle的外键默认是非延迟约束,修改学生的外键为延迟约束。

1 --删除学生表(TB_STUDENT)上的已有外键
2 ALTER TABLE TB_STUDENT DROP CONSTRAINT FK_TB_STUDENT_CLASS_ID;
3 --添加延迟约束外键
4 ALTER TABLE TB_STUDENT ADD CONSTRAINT FK_TB_STUDENT_CLASS_ID FOREIGN KEY (CLASS_ID) REFERENCES TB_CLASS (ID) ON DELETE CASCADE DEFERRABLE;

设置触发器,当班级表(TB_CLASS)的主键改变了,就更新学生表(TB_STUDENT)的外键(CLASS_ID)。

1 CREATE OR REPLACE TRIGGER TGR_TB_CLASS_UPDATE
2 AFTER UPDATE OF ID ON TB_CLASS
3 FOR EACH ROW
4 BEGIN
5   IF :OLD.ID<>:NEW.ID THEN
6     UPDATE TB_STUDENT SET CLASS_ID=:NEW.ID WHERE CLASS_ID=:OLD.ID;
7   END IF;
8 END;
时间: 2024-08-01 11:31:51

oracle系列--级联删除和级联更新的相关文章

[NHibernate]一对多关系(级联删除,级联添加)

目录 写在前面 文档与系列文章 一对多关系 一个例子 级联删除 级联保存 总结 写在前面 在前面的文章中,我们只使用了一个Customer类进行举例,而在客户.订单.产品中它们的关系,咱们并没有涉及,比如一个客户可以有一个或者多个订单,在数据库中变现为“主外键关系”,有时也喜欢称为“父子关系”.那么就让我们一起学习,在nhibernate中,是如何处理这种关系的吧? 文档与系列文章 [Nhibernate]体系结构 [NHibernate]ISessionFactory配置 [NHibernat

Oracle外键级联删除和级联更新

1 级联删除 Oracle在外键的删除上有NO ACTION(类似RESTRICT).CASCADE和SET NULL三种行为. 下面以学生-班级为例说明不同情况下的外键删除,学生属于班级,班级的主键是学生的外键. -- 班级表 CRATE TABLE TB_CLASS ( ID NUMBER NOT NULL, --班级主键 NAME VARCHAR2(50), --班级名称 CONSTRAINT PK_TB_CLASS PRIMARY KEY (ID) ); -- 学生表 CREATE TA

【Python】Django数据模型、级联删除、级联更新、ER图导出等

在本文中,我们将向读者详细介绍如何在更新和删除父表数据的同时,触发有关子表数据的级联更新和删除操作.您将看到当使用InnoDB表的时候,借助于外键约束就可以轻松搞定这一过程. 一.利用外键约束更新并删除MySQL中的数据 我们知道,开发能够维护多个表的完整性的数据库驱动的应用程序是一件非常复杂的事情--即使应用程序所面对的是当前最流行的开源关系型数据库管理系统MySQL服务器时也不例外.如果一个应用程序必须处理多个数据库表,而这些表之间有存在着某些预定义的关系,这时一旦父表中的数据被更新或者删除

仅作记录,游标,级联删除,获取所有该外键的表名

以下内容只是部分原创,仅是之前收集到的知识.只做记录避免遗忘,具体出处已遗忘. 一.游标结构 总是遗忘游标的结构 declare PeriodDataCursor cursor for select ID , ClassTime from @temptable order by [ClassTime] desc open PeriodDataCursor fetch next from PeriodDataCursor into @ID , @firstClsTime while(@@FETCH

oracle级联删除(转)

oracle中使用on delete cascade和on delete set null来建立外键 其面我们介绍了创建外键约束时如果使用oracle默认的创建方式,在删除被参照的数据时,将无法被删除,这一点在oracle9i中给了我们更多灵活的选择,我们可是使用on delete cascade和 on delete set null关键字来决定删除被参照数据时是否要将参照这个数据的那些数据一并删除,还是将那些参照这条数据的数据的对应值赋空. 例如下面这两个表中分别存的时员工的基本信息和公司的

hibernate 级联删除报更新失败的问题(org.hibernate.exception.GenericJDBCException: Could not execute JDBC batch update)

首先hibernate级联删除的前提是,首先需要在映射文件中配置,配置多表之间的关联关系: 下面以部门表(Dept)和员工表(Emp)为例: 1.在Emp.hbm.xml映射文件中配置many-to-one关系 1 <?xml version="1.0"?> 2 <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" 3 "http:/

java:Oracle(级联删除,左右内外交叉自然连接,子查询,all,any,in)

1.级联删除: -- 级联删除:裁员,公司倒闭 -- 级联删除(cascade),设置为null(setnull),放任不管(No action) -- cascade:(以一对多为例)如果删除多的一方,一的一方不受任何影响,但是如果删除一的一方,多的一方所有对应数据全部被删除 select * from staff s inner join department d on d.id = s.department_id; delete from staff s where s.id = 1; d

MySQL中利用外键实现级联删除、更新

MySQL支持外键的存储引擎只有InnoDB,在创建外键的时候,要求父表必须有对应的索引,子表在创建外键的时候也会自动创建对应的索引.在创建索引的时候,可以指定在删除.更新父表时,对子表进行的相应操作,包括RESTRICT.NO ACTION.SET NULL和CASCADE.其中RESTRICT和NO ACTION相同,是指在子表有关联记录的情况下父表不能更新:CASCADE表示父表在更新或者删除时,更新或者删除子表对应记录:SET NULL则是表示父表在更新或者删除的时候,子表的对应字段被S

关于数据的级联删除和更新

两张表:“ProductCategory”,“Product”. 有一个需求是这样的:在删除某个ProductCategory 的时候,同时删除该Category的products. 在MySQL中利用外键实现级联删除 创建以下测试用数据库表: CREATE TABLE `roottb` ( `id` INT(11) UNSIGNED AUTO_INCREMENT NOT NULL, `data` VARCHAR(100) NOT NULL DEFAULT '', PRIMARY KEY (`i