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可以的高层的数据结构上进行工作,工作时不是单条地处理记录,而对数据进行成组的处理. 统一性,操作任务主要包括:查询数据:插入.修改和删除数据 ...
随机推荐
- 蚂蚁金服SOFAMesh在多语言上的实践
在用一项技术前,一定要知道它的优点和缺点,它的优点是否对你有足够的吸引力,它的缺点不足你是否有办法补上.黄挺在CNUTCon全球运维大会上的分享也很不错. 黄挺,蚂蚁金服高级技术专家,蚂蚁金服分布式架 ...
- 大型发布会现场的 Wi-Fi 应该如何搭建(密集人群部署wifi抗干扰)?
原文连接: http://www.zhihu.com/question/20890194 WiFi网络的部署要远远比一般人想象的复杂,不是说放上几十个AP带宽就自动增加几十倍,恰恰相反,简单放几十个A ...
- 【详解】Linux的文件描述符fd与文件指针FILE*互相转换
使用系统调用的时候用文件描述符(file descriptor,简称fd)的时候比较多,但是操作比较原始.C库函数在I/O上提供了一些方便的包装(比如格式化I/O.重定向),但是对细节的控制不够. 如 ...
- 5月24日上课笔记-js操作DOM
解析properpties配置文件 类加载器 ResourceBundle 一.jquery操作DOM 1.jquery操作css css("",""); cs ...
- babun编译安装git(2.12.0)遇到的问题及解决办法
1. 下载git wget https://www.kernel.org/pub/software/scm/git/git-2.12.0.tar.xz 你或许需要加上选项: --no-check-ce ...
- oracle实例侦听
在oracle服务器端命令行中执行 C:\>lsnrctl进入到 LISNRCTL>界面 键入help字符会回显相关的帮助命令
- ManagedProperty not injected in @FacesConverter
I'm trying to inject a ManagedBean in my FacesConverted the following way: @ManagedBean @RequestScop ...
- Java Web 从入门到精通(明日科技)
目录结构: 第一章:Java Web 应用开发概述 第二章:html与css网页开发基础 第三章:JavaScript脚本语言 第四章:搭建开发环境 第五章:JSP语言基础 第六章:JSP内置对象 第 ...
- AABB和平面的相交性检测
[AABB和平面的相交性检测]
- python selenium 测试环境的搭建及python mysql的连接
又来一篇傻瓜教程啦,防止在学习的小伙伴们走弯路. 1.python 环境搭建 python官网:https://www.python.org/downloads/ 选择最新版本python下载(如果 ...