一、触发器概述

与表,视图,模式,或者数据库相关的PL/SQL过程,当触发条件被触发时,自动执行

分类:

1.语句触发器

2.行触发器

二、语句触发器

1. 什么是语句触发器

语句触发器,是指当执行DML语句时被隐含执行的触发器,如果在表上针对某种DML操作建立了语句触发器,那么当执行DML操作时会自动执行触发器的相应代码

当审计DML操作或者确保DML操作安全执行时,可以使用语句触发器,使用语句触发器时,不能记录列数据的变化

2. 语法:

create [or replace] trigger trigger_name
timing event1[or event2 or event3]
on table_name
pl/sql block;

trigger_name:用于指定触发器名
timing:指定触发时机(before或after)
event:指定触发事件(INSERT,UPDATE,和DELETE);
table_name:用于指定DML操作对应的表名

3. 语句触发器的分类

3.1 BEFORE触发器

为了确保DML操作在正常情况下执行,可以基于DML操作建立BEFORE语句触发器,例如为了禁止工作人员在休息日改变雇员信息,开发人员可以建立BEFORE语句触发器,以实现数据的安全保护

示例如下:

create or replace trigger tr_sec_emp
before insert or update or delete on emp
begin
if to_char(sysdate, 'DY', 'nls_date_language = AMERICAN') in
('SAT', 'SUN') then
raise_application_error(-, '不能在工作日修改员工信息');
end if;
end;

    修改系统日期:

[root@oracle oracle]#
[root@oracle oracle]# date
Wed Sep :: CST
[root@oracle oracle]# date -s "Wed Sep 6 22:37:27 CST 2014"
Sat Sep :: CST
[root@oracle oracle]# date
Sat Sep :: CST

提示:

SQL>update emp set sal=sal+ where empno=;

ORA-:不能在工作日修改员工信息

3.2 使用条件谓词:

当在触发器中同时包含多个触发条件(INSERT,UPDATE,DELETE)时,为了在触发器源代码中区分具体

的触发条件,可以使用三个条件谓词,可以使用以下三个条件谓词:

INSERTING:当触发事件是insert操作时,该条件谓词返回值为TRUE,否则为FALSE
UPDATING:当触发事件是UPDATE操作时,该条件谓词返回值为TRUE,否则为FALSE
DELETING:当触发事件是DELETE作时,该条件谓词返回值为TRUE,否则为FALSE

create or replace trigger tr_sec_emp
before insert or update or delete on emp
begin
if to_char(sysdate, 'DY', 'nls_date_language = AMERICAN') in
('SAT', 'SUN') then
case
when inserting then
raise_application_error(-, '不能在工作日增加员工');
when updating then
raise_application_error(-, '不能在工作日修改员工');
when deleting then
raise_application_error(-, '不能在工作日解雇员工');
end case;
end if;
end;

执行过程:

SQL> update emp set sal=sal+ where empno=;
update emp set sal=sal+ where empno=
ORA-: 不能在非工作室更新员工
ORA-: 在 "SCOTT.TR_SEC_EMP", line
ORA-: 触发器 'SCOTT.TR_SEC_EMP' 执行过程中出错

3.3 建立after语句触发器:

为了审计DML操作或者DML操作之后执行汇总运算,可以使用after触发器例如,为了审计在emp表上insert,update,delete操作次数,可以建立after触发器

在建立after触发器之前,首先建立审计表audit_table
创建审计表:

create table audit_table(name varchar2(),ins int,upd int,del int,
starttime date,endtime date);

创建触发器:

create or replace trigger tr_audit_table
after insert or delete or update on emp
declare
v_temp int;
begin
select count(*) into v_temp from audit_table where name = 'EMP';
if v_temp = then
insert into audit_table values ('EMP', , , , SYSDATE, null);
end if;
case
when inserting then
update audit_table set ins = ins + where name = 'EMP';
when deleting then
update audit_table set del = del + where name = 'EMP';
when updating then
update audit_table set upd = upd + where name = 'EMP';
end case;
end;

执行结果:

SQL> update emp set sal=sal+ where empno=;
row updated SQL> select * from audit_table;
NAME INS UPD DEL STARTTIME ENDTIME
---------- --- --- --- ----------- -----------
EMP //

ORACLE触发器概述之【语句触发器】【weber出品】的更多相关文章

  1. 全世界最详细的图形化VMware中linux环境下oracle安装(二)【weber出品必属精品】

    <ORACLE 10.2.05版本的升级补丁安装> 首先我们解压 $ unzip p8202632_10205_LINUX.zip 解压后我们会发现多出了个文件夹,他是:Disk1,进入D ...

  2. 全世界最详细的图形化VMware中linux环境下oracle安装(一)【weber出品必属精品】

    安装流程:前期准备工作--->安装ORACLE软件--->安装升级补丁--->安装odbc创建数据库--->安装监听器--->安装EM <前期准备工作> 安装 ...

  3. 使用DML语句【weber出品必属精品】

    DML语句包含以下语法: INSERT:往一个表中增加新行 DELETE:从一个表中删除掉现有的行 UPDATE:更改一个表中现有的行 INSERT语句语法:INSERT INTO TABLE(COL ...

  4. 全世界最详细的图形化VMware中linux环境下oracle安装(三)【weber出品必属精品】

    数据库软件和数据库都建好了,基本上可以说完成90%的工作,但是美中不足的就是企业管理器还没有安装好,现在我们就开始安装企业管理器吧. 安装之前我们先将补丁给补上.补丁我们也是采用禁默安装.补丁:p83 ...

  5. ORACLE【1】:触发器详解

    转自:http://blog.csdn.net/indexman/article/details/8023740 ORACLE PL/SQL编程之八: 把触发器说透 本篇主要内容如下: 8.1 触发器 ...

  6. Oracle数据库之PL/SQL触发器

    Oracle数据库之PL/SQL触发器 1. 介绍 触发器(trigger)是数据库提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是 ...

  7. ORACLE PL/SQL编程之触发器

    8.1 触发器类型 8.1.1 DML触发器 8.1.2 替代触发器 8.1.3 系统触发器 8.2 创建触发器 8.2.1 触发器触发次序 8.2.2 创建DML触发器 8.2.3 创建替代(INS ...

  8. Oracle——索引,序列,触发器

    1.索引 1)注意 oracle创建主键时会自动在该列上创建索引 2)索引原理 A.  若没有索引,搜索某个记录时(例如查找name='wish')需要搜索所有的记录,因为不能保证只有一个wish,必 ...

  9. plsql 触发器介绍 语句级别触发器、行级别触发器。

    /* 分类: 1.DDL触发器 执行create,alter,drop操作时,会激活的触发器 2.DML触发器 执行增.删除.修改时,激活的触发器 3.系统事件触发器 执行特定的系统事件时(启动.加载 ...

随机推荐

  1. MySql多条SQL语句的批量处理

    pstmt= conn.prepareStatement(sql); for(int i=0;i<500;i++) { //准备sql语句 pstmt.setString(1, "tt ...

  2. Python新手学习基础之函数-全局变量和局部变量

    全局变量和局部变量 我们通常把定义在函数外的变量成为全局变量,定义在函数内的变量称为局部变量,顾名思义,全局变量的作用域是整个代码段,局部变量的作用域就只是在它所属的代码段,变量只在它的作用域里有效. ...

  3. HTML&CSS基础学习笔记1-简单网页中有哪些标签?

    一个简单网页中有哪些HTML标签? 平时我们看到的网页,都是由HTML的标签来组成的.HTML标签非常多,我们先来认识一部分. 1. <html></html>称为根标签,所有 ...

  4. ARM 之FIQ(快速中断) IRQ(中断)

    IRQ,FIQ定义:  这就是个普通中断,当我们程序定义了该中断,并且在程序运行的时候产生了IRQ中断,则此时的芯片是这样运行的------中断处理器吧利用IRQ请求线来高速ARM,ARM就知道有个I ...

  5. Windows server 2012 各版本 激活方法

    Windows server 2012 激活教程 本文包括以下两种版本的激活过程:(注意RC版的是不能激活的!) 1.Windows server 2012 试用版本激活 2.Windows serv ...

  6. Java学习笔记--“==”与"equals"

    java中的数据类型,可分为两类: 1. 基本数据类型,也称原始数据类型.byte,short,char,int,long,float,double,boolean 他们之间的比较,应用双等号(==) ...

  7. 转:AM335x启动流程(BootRom->MLO->Uboot)

    http://blog.chinaunix.net/uid-28458801-id-3486399.html 参考文件: 1,AM335x ARM Cortex-A8 Microprocessors ...

  8. pthread_mutex_init & 互斥锁pthread_mutex_t的使用

    pthread_mutex_init l         头文件: #include <pthread.h> l         函数原型: int pthread_mutex_init( ...

  9. Oracle查询死锁&杀死会话

    select object_name,machine,s.sid,s.serial#  from v$locked_object l,dba_objects o ,v$session s where ...

  10. SRM 599 DIV1

    A 首先发现对于2操作,每种素因子可以单独考虑,然后取出步数最多的计入答案,然后分别加上对每种素因子的1操作; 第二步我犯了个错误,以为最优方案是把素因子指数按二进制操作,在1的位置执行1操作,0的位 ...