十四、触发器(监听数据操作的工具)
1、什么是触发器?
数据库触发器是一个与表相关联的、存储的PL/SQL程序
作用:
每当一个特定的数据操作语句(insert、update、delete)在指定的表上发出时,Oracle自动地执行触发器中定义的语句序列。

事例:
第一个触发器:每当成功插入新员工后,自动打印“成功插入新员工”。(触发器的单词:trigger)
如何创建触发器(命令窗口)
create trigger saynewemp
after insert
on emp
declare
begin
DBMS_OUTPUT.PUT_LINE('成功插入新员工');
end;
/

insert into emp(empno,ename,sal,deptno) values(1001,'XiaoBaiTu',3000,10);

2、触发器的应用场景
(1)复杂的安全性检查
周末不能操作数据库
(2)数据确认
涨后工资大于涨前工资才能操作
(3)实现审计功能
跟踪表上的数据操作
(4)完成数据的备份和同步

3、触发器的语法
创建触发器的语法
create orreplace trigger 触发器名
{before|after}
{delete|insert}
on 表名
[for each row [when(条件)]]
PL/SQL块
4、触发器的类型
(1)语句级触发器
--在指定的操作语句操作之前或之后执行一次,不管这条语句影响了多少行.
[for each row]]没有这句就是语句级触发器
(2)行级触发器
--触发语句作用的每一条记录都被触发.在行级触发器中使用old和:new伪记录变量,识别值的状态.
[for each row]]有这句就是行级触发器

事例:
insert into emp10 select* from emp where deptno=10;

语句级触发器:针对是表 影响三张表的操作,只会操作一次
行级触发器:针对是行 操作三次

5、案例
触发器案例一:复杂的安全性检查
(1)禁止在非工作时间插入数据
查询周六和周日
select to_char(sysdate,'day') from dual;
思路:
1、周末:to_char(sysdate,'day') in ('星期六','星期日')
2、上班前,下班后:to_number(to_char(sysdate,'hh24')) not between 9 and 18

PL/SQL语句
create or replace trigger securityemp
before insert
on emp
begin
if to_char(sysdate,'day') in('星期六','星期日') or
to_number(to_char(sysdate,'hh24')) not between 9 and 18 then
--禁止insert新员工
raise_application_error(-20001,'禁止在非工作时间插入新员工');
end if;
end;
/
执行插入语句:
insert into emp(empno,ename,sal,deptno) values(1001,'XiaoBaiTu',3000,10);
会报错:禁止在非工作时间插入新员工
就是成功了

触发器案例二:数据的确认
(1)涨工资不能越涨越少(行级触发器)
思维:
1、:old和:new代表同一条记录
2、:old表示操作该行之前,这一行的值
:new表示操作该行之后,这一行的值
create or replace trigger checksalary
before update
on emp
for each row
begin
--if涨后的薪水<涨前的薪水then
if :new.sal<:old.sal then
--涨后的薪水不能少于涨前的薪水
raise_application_error(-20002,'涨后的薪水不能少于涨前的薪水'||'涨后的薪水:'||:new.sal||'涨前的薪水'||:old.sal);
end if;
end;
/

涨工资测试:
正常测试:
update emp set sal=sal+1 where empno=7839;
触发测试:
update emp set sal=sal-1 where empno=7839;

触发器案例三:数据库审计
(1)创建基于值的触发器
--给员工涨工资,当涨后的薪水超过6000块钱时,审计该员工的信息

--创建表,用于保存审计信息
create table audit_info
(
information varchar2(200)
);
--创建触发器
create or replace trigger do_audit_emp_salary
after update
on emp
for each row
begin
--当涨后的薪水大于6000,插入审计信息
if :new.sal>6000 then
insert into audit_info values(:new.empno||' '||:new.ename||' '||:new.sal);
end if;
end;
/

涨工资测试:
触发测试:
update emp set sal=sal+2000;

触发器案例四:数据的备份和同步
(1)利用触发器实现数据的同步部分
--创建备份表
create table emp_bak as select * from emp;
--当给员工涨完工资后,自动备份新的工资到备份表中

查看备份表中信息
select sal from emp_bak where empno=7839;

PL/SQL开发
--创建触发器
create or replace trigger sync_salary
after update
on emp
for each row
begin
--当主表更新后,自动进行更新备份
update emp_bak set sal=:new.sal where empno=:new.empno;
end;
/

更新数据到主表中
update emp set sal=sal+10 where empno=7839;

还有一种方式是快照备份
区别是:触发器是同步备份,快照是异步

Oracle学习笔记(十三)的更多相关文章

  1. Oracle学习笔记十三 触发器

    简介 触发器是当特定事件出现时自动执行的存储过程,特定事件可以是执行更新的DML语句和DDL语句,触发器不能被显式调用.   触发器的功能: 1.自动生成数据 2.自定义复杂的安全权限 3.提供审计和 ...

  2. Oracle学习笔记三 SQL命令

    SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)  

  3. python3.4学习笔记(十三) 网络爬虫实例代码,使用pyspider抓取多牛投资吧里面的文章信息,抓取政府网新闻内容

    python3.4学习笔记(十三) 网络爬虫实例代码,使用pyspider抓取多牛投资吧里面的文章信息PySpider:一个国人编写的强大的网络爬虫系统并带有强大的WebUI,采用Python语言编写 ...

  4. java之jvm学习笔记十三(jvm基本结构)

    java之jvm学习笔记十三(jvm基本结构) 这一节,主要来学习jvm的基本结构,也就是概述.说是概述,内容很多,而且概念量也很大,不过关于概念方面,你不用担心,我完全有信心,让概念在你的脑子里变成 ...

  5. oracle学习笔记第一天

    oracle学习笔记第一天 --oracle学习的第一天 --一.几个基础的关键字   1.select select (挑选) 挑选出显示的--列--(可以多列,用“,”隔开,*表示所有列),为一条 ...

  6. Go语言学习笔记十三: Map集合

    Go语言学习笔记十三: Map集合 Map在每种语言中基本都有,Java中是属于集合类Map,其包括HashMap, TreeMap等.而Python语言直接就属于一种类型,写法上比Java还简单. ...

  7. Oracle学习笔记——点滴汇总

    Oracle学习笔记——点滴汇总 http://www.botangdb.com/ Oracle GI = Grid Infrastructure = ASM + Cluster

  8. Oracle学习笔记之四sp1,Oracle 11g的常用函数

    从Oracle学习笔记之四,SQL语言入门中摘出来的,独立成一章节 3.1 字符类函数 ASCII(c)和CHR(i)    分别用于返回一个字符的ASCII码和返回给定ASCII值所对应的字符. C ...

  9. Oracle学习笔记之四,SQL语言入门

    1. SQL语言概述 1.1 SQL语言特点 集合性,SQL可以的高层的数据结构上进行工作,工作时不是单条地处理记录,而对数据进行成组的处理. 统一性,操作任务主要包括:查询数据:插入.修改和删除数据 ...

随机推荐

  1. 首页大屏广告效果 jquery轮播图淡入淡出

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  2. javaweb经典面试题

    1.hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,使得java程序员可以随心所欲的使用对象编程思维来操纵数据库. 工作原理: 1.读取并解析配置文件2. ...

  3. Spring线程池ThreadPoolTaskExecutor配置及详情

    Spring线程池ThreadPoolTaskExecutor配置及详情 1. ThreadPoolTaskExecutor配置 <!-- spring thread pool executor ...

  4. 负载均衡-haproxy安装配置

    HAProxy提供高可用性.负载均衡以及基于TCP和HTTP应用的代理,支持虚拟主机,它是免费.快速并且可靠的一种解决方案.HAProxy特别适用于那些负载特大的web站点,这些站点通常又需要会话保持 ...

  5. 控件m

    窗体的事件:删除事件:先将事件页面里面的挂好的事件删除,再删后台代码里面的事件 Panel是一个容器 1.Label -- 文本显示工具Text:显示的文字取值.赋值:lable1.Text 2.Te ...

  6. Esxi5-管理平台vcenter5.0_数据库迁移流程

    migrating-vcenter-database-express-to-sql-2008-r2 一.      准备环境. ESXi5.0主机      IP:192.168.1.158      ...

  7. jetty之嵌入式开发

    一.Jetty 是一个开源的servlet容器,它为基于Java的web容器,例如JSP和servlet提供运行环境.Jetty是使用Java语言编写的,它的API以一组JAR包的形式发布.开发人员可 ...

  8. 深入解析thinkphp中的addAll方法

  9. 详解Oracle的几种分页查询语句

    转载自:http://database.51cto.com/art/200904/118737.htm 分页查询格式: SELECT * FROM (SELECT A.*, ROWNUM RN FRO ...

  10. 六.jQuery源码分析之jQuery原型属性和方法

    97 jQuery.fn = jQuery.prototype = { 98 constructor: jQuery, 99 init: function( selector, context, ro ...