2024-03-19
原文作者:吴声子夜歌 原文地址: https://blog.csdn.net/cold___play/article/details/103847413

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;

202403192031410031.png编写触发器:

    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;

测试:

202403192031412722.png
查看基表:

202403192031415613.png

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

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

阅读全文