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可以的高层的数据结构上进行工作,工作时不是单条地处理记录,而对数据进行成组的处理. 统一性,操作任务主要包括:查询数据:插入.修改和删除数据 ...
随机推荐
- Android实现带图标的ListView
版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/bear_huangzhen/article/details/23991119 Android实现带图 ...
- Jenkins在windows环境下安装无法安装插件
在windos平台下安装jenkins要是无法安装插件,tomcat控制台报以下错误: 解决方法: 进入到jenkins里头,Jenkins -- 管理插件 -- 高级 -- 升级站点,如图所示: 将 ...
- vue通过(NGINX)部署在子目录或者二级目录实践
1.修改 router/index.js 添加一行 base: 'admin', 2.然后修改 config/index.js 增加一行 const assetsPublicPath = '/admi ...
- vagrant 相关记录
最近安装vagrant 出错的最大的可能性是BOX 路径不太对, 好像和目录的大小写有关系,请检查 $ vagrant init # 初始化$ vagrant up # 启动虚拟机$ vagrant ...
- eaccelerator详解
之前在看书的时候看到一个eaccelerator,以前也没用过 不知道是啥东东,不知道以后会用到不,先mark一下吧 eAccelerator是一个自由开放源码php加速器,优化和动态内容缓存,提高了 ...
- map、reduce处理数据结构及常见案例
随着三大前端框架和小程序的流行,MVVM大行其道,而其中的核心是 ViewModel 层,它就像是一个中转站(value converter),负责转换 Model 中的数据对象来让数据变得更容易管理 ...
- Python调用R语言
网络上经常看到有人问数据分析是学习Python好还是R语言好,还有一些争论Python好还是R好的文章.每次看到这样的文章我都会想到李舰和肖凯的<数据科学中的R语言>,书中一直强调,工具不 ...
- Quartz实现JAVA定时任务的动态配置
什么是动态配置定时任务? 首先说下这次主题,动态配置.没接触过定时任务的同学可以先看下此篇:JAVA定时任务实现的几种方式 定时任务实现方式千人千种,不过基础的无外乎 1.JDK 的Timer类 2. ...
- Servlet类源码说明
servlet是学习java web不可不懂的一个类,网上各种教程都参杂太多,每次理解都感觉像把别人吐出来的食物再放在嘴里咀嚼,小编一怒之下,直接打开源码,原汁原味的芬芳扑面而来: /** * Def ...
- 跟我学算法- tensorflow 实现RNN操作
对一张图片实现rnn操作,主要是通过先得到一个整体,然后进行切分,得到的最后input结果输出*_w[‘out’] + _b['out'] = 最终输出结果 第一步: 数据载入 import ten ...