Oracle--替代触发器(INSTEAD OF)

INSTEAD OF触发器

INSTEAD OF触发器主要用来对另一个表或视图进行DML操作。与DML触发器不同,在定义替代触发器后,用户对表的DML操作将不再被执行,而是执行触发器主体中的操作。使用替代触发器的一个常用情况是对视图的操作,如果一个试图由多个基表连接而成,则该视图不允许进行INSERT、UPDATE和DELETE这样的DML操作。当在视图上编写替代触发器后,用户对视图的DML操作就不会执行,而是执行触发器中的PL/SQL语句块,这样就可以通过在替代触发器中编写适当的代码,完成对组成视图的各个表进行操作。

使用触发器对基于多个表建立的视图进行更新
创建一个视图,显示学生信息,课程信息和选课信息

create view stu_course_sc as
select s.*,c.*,sc.grade from student s,course c,SC sc
where s.Sno=sc.Sno and c.Cno=sc.Cno;

在这里插入图片描述编写触发器:

create or replace trigger tr_stu_view
instead of update
on stu_course_sc
for each row
begin
  --更新Student表--
  update student set SNAME=:new.SNAME where SNO=:NEW.SNO;
  --更新course表--
  update course set CNAME=:new.CNAME where CNO=:old.CNO;
  --更新sc表--
  update sc set GRADE=:new.GRADE where SNO=:new.SNO and CNO=:old.CNO;
end;

测试:

在这里插入图片描述
查看基表:
在这里插入图片描述

需要注意的是,视图的更新操作也要遵循基表自身的约束机制。

另外,在创建替代触发器时,没有BEFORE和AFTER关键字,INSTEAD OF总是等同于使用AFTER关键字的行级触发器,它会为每个受到影响的行触发一次,用户不能修改其中的:NEW值。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值