Oracle学习笔记(十三)
十四、触发器(监听数据操作的工具)
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学习笔记(十三)的更多相关文章
- Oracle学习笔记十三 触发器
简介 触发器是当特定事件出现时自动执行的存储过程,特定事件可以是执行更新的DML语句和DDL语句,触发器不能被显式调用. 触发器的功能: 1.自动生成数据 2.自定义复杂的安全权限 3.提供审计和 ...
- Oracle学习笔记三 SQL命令
SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)
- python3.4学习笔记(十三) 网络爬虫实例代码,使用pyspider抓取多牛投资吧里面的文章信息,抓取政府网新闻内容
python3.4学习笔记(十三) 网络爬虫实例代码,使用pyspider抓取多牛投资吧里面的文章信息PySpider:一个国人编写的强大的网络爬虫系统并带有强大的WebUI,采用Python语言编写 ...
- java之jvm学习笔记十三(jvm基本结构)
java之jvm学习笔记十三(jvm基本结构) 这一节,主要来学习jvm的基本结构,也就是概述.说是概述,内容很多,而且概念量也很大,不过关于概念方面,你不用担心,我完全有信心,让概念在你的脑子里变成 ...
- oracle学习笔记第一天
oracle学习笔记第一天 --oracle学习的第一天 --一.几个基础的关键字 1.select select (挑选) 挑选出显示的--列--(可以多列,用“,”隔开,*表示所有列),为一条 ...
- Go语言学习笔记十三: Map集合
Go语言学习笔记十三: Map集合 Map在每种语言中基本都有,Java中是属于集合类Map,其包括HashMap, TreeMap等.而Python语言直接就属于一种类型,写法上比Java还简单. ...
- Oracle学习笔记——点滴汇总
Oracle学习笔记——点滴汇总 http://www.botangdb.com/ Oracle GI = Grid Infrastructure = ASM + Cluster
- Oracle学习笔记之四sp1,Oracle 11g的常用函数
从Oracle学习笔记之四,SQL语言入门中摘出来的,独立成一章节 3.1 字符类函数 ASCII(c)和CHR(i) 分别用于返回一个字符的ASCII码和返回给定ASCII值所对应的字符. C ...
- Oracle学习笔记之四,SQL语言入门
1. SQL语言概述 1.1 SQL语言特点 集合性,SQL可以的高层的数据结构上进行工作,工作时不是单条地处理记录,而对数据进行成组的处理. 统一性,操作任务主要包括:查询数据:插入.修改和删除数据 ...
随机推荐
- 首页大屏广告效果 jquery轮播图淡入淡出
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- javaweb经典面试题
1.hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,使得java程序员可以随心所欲的使用对象编程思维来操纵数据库. 工作原理: 1.读取并解析配置文件2. ...
- Spring线程池ThreadPoolTaskExecutor配置及详情
Spring线程池ThreadPoolTaskExecutor配置及详情 1. ThreadPoolTaskExecutor配置 <!-- spring thread pool executor ...
- 负载均衡-haproxy安装配置
HAProxy提供高可用性.负载均衡以及基于TCP和HTTP应用的代理,支持虚拟主机,它是免费.快速并且可靠的一种解决方案.HAProxy特别适用于那些负载特大的web站点,这些站点通常又需要会话保持 ...
- 控件m
窗体的事件:删除事件:先将事件页面里面的挂好的事件删除,再删后台代码里面的事件 Panel是一个容器 1.Label -- 文本显示工具Text:显示的文字取值.赋值:lable1.Text 2.Te ...
- Esxi5-管理平台vcenter5.0_数据库迁移流程
migrating-vcenter-database-express-to-sql-2008-r2 一. 准备环境. ESXi5.0主机 IP:192.168.1.158 ...
- jetty之嵌入式开发
一.Jetty 是一个开源的servlet容器,它为基于Java的web容器,例如JSP和servlet提供运行环境.Jetty是使用Java语言编写的,它的API以一组JAR包的形式发布.开发人员可 ...
- 深入解析thinkphp中的addAll方法
- 详解Oracle的几种分页查询语句
转载自:http://database.51cto.com/art/200904/118737.htm 分页查询格式: SELECT * FROM (SELECT A.*, ROWNUM RN FRO ...
- 六.jQuery源码分析之jQuery原型属性和方法
97 jQuery.fn = jQuery.prototype = { 98 constructor: jQuery, 99 init: function( selector, context, ro ...