如何在Oracle中使用触发器?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
<强>触发器类型强>
触发器在数据库里以独立的对象存储,它与存储过程和函数不同的是,存储过程与函数需要用户显示调用才执行,而触发器是由一个事件来启动运行。即触发器是当某个事件发生时自动地隐式运行,并且,触发器不能接收参数,所以运行触发器就叫触发或点火(解雇).ORACLE事件指的是对数据库的表进行的插入、更新及删除操作或对视图进行类似的操作.ORACLE将触发器的功能扩展到了触发甲骨文,如数据库的启动与关闭等。所以触发器常用来完成由数据库的完整性约束难以完成的复杂业务规则的约束,或用来监视对数据库的各种操作,实现审计的功能。
开发中肯定会用到甲骨文的触发器,本文进行详细讲解。
这里实例中用到的主要是甲骨文中斯科特用户下的电磁脉冲以及部门表,数据如下
<强>一、触发器概念强>
<强> 1,概念:强>
触发器的本质是一个存储过程,顾名思义发生特定事件时甲骨文会执行触发器中的代码。细分它的组成可以分为3个部分:第一部分在什么条件下触发器会执行,即触发器被触发的事件。第二部分在什么时间点执行触发器即触发器的发生事件例如前、后。第三部分触发器自身所要做的事情,就是触发器被触发以后具体想表达的事件,在开始和结束之间的sql。
<强>二、触发器的分类:强>
<强> 1,ddl触发器:即执行ddl操作后所触发的事件。强>
常用的ddl操作有:格兰特(授权),撤销(撤销授权),创建(创建),下降(删除),改变(修改),评论(注释),审计(审核),重命名(重命名)在进行具体实例以前先来讲解另一个概念:甲骨文中的用户和模式:
用户:甲骨文中的用户,拥有数据库的对象以及对数据库对象增删改查的权限. schema:该用户下所有数据库对象的集合。类似于生活中房子模式和房子的拥有者用户之间的关系,你是一个用户用户你可以通过改变会话查看别人的房子,但是你是否可以改变房子中的家具,要看这个房子的拥有者是否给予你这个权限,除非你是所有房子的最高权限人dba。
ddl的例子:禁止斯科特用户的所有ddl操作
CREATE 或是REPLACE TRIGGER scott_trigger BEFORE DDL 提醒模式 开始 ,RAISE_APPLICATION_ERROR(-20008 & # 39;禁止斯科特用户的所有ddl操作& # 39;); 结束;
create sequence myseq;
这里看到在创建触发器以后如果仍然使用ddl操作,便会报错。
<强> 2,dml触发器:基于dml操作的触发器,细分又可以分为行触发器和语句触发器。强>
,语句触发器:dml操作可能会影响很多行,主要用于对数据的安全保护。
例子:禁止在周四,周五修改emp表数据
create 或是REPLACE TRIGGER emp_trigger BEFORE UPDATE 或是DELETE 或插入 提醒emp 开始 ,IF to_char (sysdate & # 39;天# 39;),拷贝(& # 39;星期四& # 39;,& # 39;星期五& # 39;), ,RAISE_APPLICATION_ERROR(-20008 & # 39;不允许在周四周五修改emp表& # 39;); ,最终获得;如果; 结束;
update emp set sal=800;
这里建立触发器以后,当你想改变所有人的工资时就会出触发器的错误,所有人的工资即表示会影响很多行。
B,行级触发器:针对需要操作的那一行,有关键词:对于每一行,用来
(1)实现数据的审计功能:
例子:做一个记录删除员工信息的表记录被删除员工的信息
这里为了不改变甲骨文中emp表的数据,新建一个emp_new表
create table emp_new 作为 select *,得到电磁脉冲;
create table emp_audit (name varchar2 (10), delete_time 日期),