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值。