博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Oracle--替代触发器(INSTEAD OF)
阅读量:2442 次
发布时间:2019-05-10

本文共 882 字,大约阅读时间需要 2 分钟。

INSTEAD OF触发器

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

使用触发器对基于多个表建立的视图进行更新

创建一个视图,显示学生信息,课程信息和选课信息

create view stu_course_sc asselect s.*,c.*,sc.grade from student s,course c,SC scwhere s.Sno=sc.Sno and c.Cno=sc.Cno;

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

create or replace trigger tr_stu_viewinstead of updateon stu_course_scfor each rowbegin  --更新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值。

转载地址:http://okpqb.baihongyu.com/

你可能感兴趣的文章
响应式屏幕_检测角度的响应式屏幕尺寸
查看>>
使用Visual Studio Code调试Go代码
查看>>
使用Async的异步Javascript-等待
查看>>
vue中使用vuex_使用Vuex在Vue中处理身份验证
查看>>
JavaScript中的面向对象编程
查看>>
报纸打字项目_使用打字稿设置节点项目
查看>>
nuxt.js 全局 js_在Nuxt.js应用中实现身份验证
查看>>
具有NgClass和NgStyle的Angular 2+类
查看>>
网络抓取_使用ScrapeStack轻松进行网络抓取
查看>>
koa express_Koa简介-Express的未来
查看>>
github请求超时_在GitHub中创建第一个请求请求
查看>>
JavaScript函数式编程介绍:使用map(),filter()和reduce()进行列表处理
查看>>
使用Apollo在React中实现GraphQL
查看>>
vue vue-jsx标签_将JSX与Vue一起使用以及为什么要关心
查看>>
实时获取汇率_Currencylayer实时汇率
查看>>
okta使用_使用模具和Okta将身份验证添加到您的PWA中
查看>>
scotch 安装_建立新的Scotch.io动画SVG徽标
查看>>
tailwind css_15分钟内开始使用Tailwind CSS
查看>>
react中创建一个组件_在React中创建社交关注组件
查看>>
stellar js_在10分钟内制作一个Stellar React + NASA App
查看>>