网站首页 > 技术文章 正文
Oracle DML类型触发器
Oracle DML类型触发器是Oracle开发过程当中最经常用到,也是最常见的触发器,主要是对DML操作,如:insert、delete、update操作事件进行触发。
DML类型触发器安装触发的事件的前后和数据触发的类型可以分为四类:前置行级触发器、后置行级触发器、前置语句级触发器、后置语句级触发器。
创建DML类型触发器的语法结构如下:
create [ or replace] trigger tr_name(触发器名) before|after delete| insert | update [of column1,column2...] [or delete |insert| update of colum1,colum2...] on table_name(表名) [for each row] [follows tr_name1(其它触发器名)] [when 条件] declare --声明部分 begin --触发器内容部分 end;
语法解析:
1、or replace :存在同名的触发器就覆盖保存。
2、trigger:创建触发器的关键词。
3、before|after表示是选择的触发器是数据改变之前触发、数据改变之后触发。
4、delete| insert | update:表示触发器触发的事件类型是删除、插入或更新。
5、for each row: 表示行级触发器、不填就是语句级触发器
6、follows :表示触发器的顺序是跟在哪个之后。
7、when 表示触发器语句触发的条件
行级触发器
行级触发器一般用来做数据的校验或者记录数据的操作日志,下面是一个行级触发器的例子:
案例1、利用行级触发器记录更新学生信息表时的操作记录,代码如下:
create or replace trigger tr_stuinfo_update before update on stuinfo for each row begin --当学生班号发生变化时, if :new.CLASSNO <> :old.CLASSNO then --插入操作日志表 insert into oplog (LOGID, --日志ID TABLENAME, --表名 COLNAME, --列名 NEWDATA, --改变后数据 OLDDATA, --改变前数据 OPDATE, --操作时间 OPERATOR) --操作人 values (pk_oplog_id.nextval, 'stuinfo', 'classno', :new.classno, :old.classno, sysdate, 'jsq'); end if; end;
代码解析:
1、这是一个学生信息表(stuinfo)update的前置行级触发器,当修改学生的班号时,会把修改的记录的操作信息记录在日志表(oplog)中。
2、行级触发器通过:new和:old来访问变化之后的数据和变化之前的数据,update类型触发器,新旧数据都可以访问,delete类型触发器,只能访问:old值,insert类型触发器只能访问:new值。
建立好触发器,我们更改一条数据看下效果,代码如下:
update stuinfo t set t.classno = 'C201802' where t.stuid = 'SC201801006'; select * from oplog;
结果如下:
语句级触发器
语句级触发器一般是用来做特定限制语句操作的作用,比如在某一段时间内禁止某一部分语句操作,下面是一个语句级触发器的案例:
案例2、比如今天是12月15号,我就禁止每月的15号禁止操作学生信息表(stuinfo)的插入和删除或修改操作。代码如下:
create or replace trigger tr_stuinfo_sql before update or insert or delete on stuinfo begin --每月15号禁止操作学生信息表 if to_char(sysdate,'dd')='15' then raise_application_error(-20001,'每月15号不能对学生信息表进行正删改操作!'); end if; end;
代码解析:
1、DML语句触发器就是行级触发器省略掉for each row的写法。
2、raise_application_error是主动给客户端抛出-20001代码错误的信息。
建立好触发器,我们更新一条数据看下效果,结果如下:
总结:
同一个对象上可以有多个DML触发器,但是触发器触发的时候有先后顺序,比如before型触发器比after型触发器先触发,在此基础上行级触发器,比语句级触发器更早触发。同类型的触发器的先后顺序就按follows关键词+触发器名进行排序。
猜你喜欢
- 2024-10-13 通过触发器截取插入Oracle的数据长度
- 2024-10-13 ORACLE 19C 触发器自动打开PDB oracle 触发器执行出错
- 2024-10-13 干货 oracle sql 存储过程、触发器、方法
- 2024-10-13 Oracle数据库面试题汇总 oracle数据库面试题基础知识
- 2024-10-13 Oracle数据库知识 day02 索引&pl/sql语法&存储过程&触发器
- 2024-10-13 Oracle笔试题库 附参考答案 oracle笔试题目及答案
- 2024-10-13 Oracle 创建表的序列和触发器 oracle给表添加触发器
- 2024-10-13 分享一个实用的触发器--限制Oracle用户登录IP地址
- 2024-10-13 利用Oracle触发器实现不同数据库之间的数据同步
- 2024-10-13 Oracle触发器的简单例子 oracle中触发器分为哪几种
你 发表评论:
欢迎- 05-11FANUC修改前端目录教程
- 05-11前端分享-Set你不知道的事
- 05-11jq+ajax+bootstrap改了一个动态分页的表格
- 05-11千万级大表分页查询效率剧降,你会怎么办?
- 05-11Elasticsearch深度分页
- 05-11如何写一个简单的分页
- 05-11手速太快引发分页翻车?前端竞态陷阱揭秘
- 05-11「linux」Socket缓存是如何影响TCP性能的?
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端md5加密 (49)
- 前端路由 (55)
- 前端数组 (65)
- 前端定时器 (47)
- 前端懒加载 (45)
- 前端接口 (46)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle约束 (46)
- oracle 中文 (51)
- oracle链接 (47)
- oracle的函数 (57)
- mac oracle (47)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)