PL/SQL 07 触发器 trigger
--触发器
触发器有三类:
数据操作触发器
用before触发器进行数据校验
用after触发器进行级联操作
语句触发器限制数据的操作和记录操作日志
instead of 触发器(只针对视图不允许DML操作时)
数据定义触发器
监视数据库中用户的一些重要操作
系统触发器
--触发器的限制
不应该使用事务控制语句
COMMIT, ROLLBACK, SAVEPOINT
由触发器调用的任何过程与函数都不能使用事务控制语句
不能声明任何LONG或LONG RAW变量
可以访问的表有限
变化表
被DML语句正在修改的表,亦即定义触发器的表
限制表
有些表在创建的时候就带有参考完整性限制的声明
主键与外键
触发器主体中的限制
不可以读取或修改任何变化表
不可以读取或修改限制表的主键,唯一值列,外键列
--数据操作触发器
create or replace trigger 触发器名字
before/after insert/update/delete
on 表名/视图名
for each row
declare
变量定义;
begin
代码;
end;
--for each row为行级触发器,去掉为语句级触发器
:new.字段 数据操作后的内容
:old.字段 数据操作前的内容
--禁止向t_score表中添加微机原理的成绩
create or replace trigger trg_insert_sco
before insert
on t_score
for each row
declare
coursename t_course.coursename%type;
begin
select coursename
into coursename
from t_course
where courseno=:new.courseno;
if coursename='微机原理' then
raise_application_error(-20001,'该课程已经考试结束,不能添加成绩记录');
end if;
end;
--当学生表中添加一条记录时,自动为此学生添加高等数学期中成绩,分数设为null
create or replace trigger trg_insert_stu
after insert
on t_student
for each row
begin
insert into t_score
values(:new.stuno,'期中',(select courseno
from t_course
where coursename='高等数据'),null);
end;
--语句触发器
--禁止8:00到18:00对成绩表进行操作
create or replace trigger trg_ope_sco
before insert or update or delete
on t_score
begin
if (to_char(sysdate,'hh24:mi') not between '8:00' and '18:00')
then
raise_application_error(-20004,'不能再非工作时间对t_score表进行操作');
end if;
end;
--instead of 触发器
--对于含有连接或子查询的视图,一般无法进行DML操作,可以用instead of 触发器实现
create or replace trigger 触发器名字
instead of insert/update/delete
on 视图名
for each row
declare
变量定义;
begin
代码;
end;
create or replace trigger trg_update_vw_cou_tea
instead of update
on vw_cou_tea
for each row
declare
tno t_teacher.teano%type;
begin
select teano
into tno
from t_teacher
where teaname=:new.teaname;
update t_course
set teano=tno
where coursename=:old.coursename;
end;
--数据定义语言触发器
create or replace trigger 触发器名字
before/after 用户事件
on database|schema
declare
变量定义;
begin
代码;
end;
--用户事件包括create、alter、drop、用户登录login等
--禁止用户删除数据库对象
create or replace trigger trg_drop
before drop
on schema
begin
raise_application_error(-20005,'不能删除');
end;
--触发器(OEM)
create trigger bmbtrigger
before insert or update or delete
on bmb
begin
if(to_char(sysdate,'DAY'))='SUN'
then
RAISE_APPLICATION_ERROR(-20600,'you can not update table on weekend.');
end if;
end;
create or replace trigger gzbtrigger
after insert or update or delete
on gzb
declare suminconme number
begin
select sum(income) into sumincome from gzb;
if sumincome<50000
then
raise_application_error(-20001,'收入低于2万');
end if;
end;
PL/SQL 07 触发器 trigger的更多相关文章
- Oracle数据库编程:使用PL/SQL编写触发器
8.使用PL/SQL编写触发器: 触发器存放在数据缓冲区中. 触发器加序列能够实现自动增长. 在触发器中不能使用connit和rollback. DML触发器 ...
- PL/SQL之--触发器
一.简介 触发器在数据库里以独立的对象进行存储,它与存储过程和函数不同的是,存储过程与函数需要用户显示调用才执行,而触发器是由一个事件来触发运行.oracle事件指的是对数据库的表或视图进行的inse ...
- ORACLE PL/SQL:触发器
ORACLE PL/SQL 触发器 本篇主要内容如下: 8.1 触发器类型 8.1.1 DML触发器 8.1.2 替代触发器 8.1.3 系统触发器 8.2 创建触发器 8.2.1 触发器触发次序 8 ...
- 开发PL/SQL子程序和包及使用PL/SQL编写触发器、在JDBC中应用Oracle
1. 子程序的各个部分: 声明部分.可执行部分.异常处理部分(可选) 2.子程序的分类: A. 过程 - 执行某些操作 a. 创建过程的语法: CREATE [OR REPLACE] PROC ...
- 【PL/SQL】触发器示例:记录加薪
首先创建一张表,用于保存薪资变化情况: --创建加薪记录表 CREATE TABLE scott.raisedsalarylog ( empno ) NOT NULL PRIMARY KEY, --员 ...
- 全面对比T-SQL与PL/SQL
1)数据类型 TSQL PL/SQL numeric(p,s) numeric(p,s) or NUMBER(p,s) decimal(p,s) decimal(p,s) or NUMBER(p,s) ...
- PL/SQL详细介绍,设置oracle相关
1. 实现参照完整性 指若两个表之间具有主从关系(即主外键关系),当删除主表数据时,必须确保相关的从表数据已经被删除. 当修改主表的主键列数据时,必须确保相关从表数据已经被修改.为了实现级 ...
- PL/SQL -->隐式游标(SQL%FOUND)
PL/SQL -->隐式游标(SQL%FOUND) 分类: SQL/PLSQL 基础2010-12-22 16:23 4084人阅读 评论(0) 收藏 举报 sqlexceptionoracle ...
- oracle PL/SQL(procedure language/SQL)程序设计之触发器(trigger)
创建触发器 触发器类似于过程和函数,都拥有声明.执行和异常处理过程的带名PL/SQL块.与包类似,触发器必须存储在数据库中.前面已经讲过,过程是显式地通过过程调用执行的,同时过程调用可以传递参数.与之 ...
随机推荐
- Docker安装Zabbix全记录
零.Zabbix架构设计 一.docker安装mysql 查找Docker Hub上的mysql镜像: [root@10e131e69e15 ~]# docker search mysql INDEX ...
- 1072 Gas Station (30 分)(最短路径)
#include<bits/stdc++.h> using namespace std; ; int n,m,k,Ds; int mp[N][N]; int dis[N]; int vis ...
- 关于缺失值(missing value)的处理---机器学习 Imputer
关于缺失值(missing value)的处理 在sklearn的preprocessing包中包含了对数据集中缺失值的处理,主要是应用Imputer类进行处理. 首先需要说明的是,numpy的数组中 ...
- 深夜浅谈我理解的DIV对SEO的影响
又到了夜深人静的时候,对于以前的我来说每天的这个时候都是在敲一下代码啊或者看一会书,但是今夜突然间又一次心血来潮,想写一篇博文来记录一下这一段时间做SEO优化所遇到的问题. 其实对于我来说SEO并不是 ...
- 并发(一) Semaphore
Semaphore 控制对资源的并发访问数,构造时如果传参为1,则近似于ReentrantLock,差别在于锁的释放.可以一个线程获取锁,另外一个线程释放锁,在一些死锁处理的场合比较适用. 如上所示, ...
- 子查询 做where条件 做 from的临时表 ,做select的一个字段 等
子查询 做where条件 做 from的临时表 ,做select的一个字段 等
- c# 以多个字符串分隔字符串数据 分组 分隔 split 正则分组
string str="aaa[##]ccc[##]ddd[##]bb" Regex regex=new Regex("[##]");//以 [##] 分割 s ...
- C++——类继承以及类初始化顺序
对于类以及类继承, 几个主要的问题:1) 继承方式: public/protected/private继承. 这是c++搞的, 实际上继承方式是一种允许子类控制的思想. 子类通过public继承, 可 ...
- 【bzoj2756 奇怪的游戏】
Time Limit: 40 Sec Memory Limit: 128 MBSubmit: 4403 Solved: 1226[Submit][Status][Discuss] Descript ...
- C#语法糖大汇总【转发】
首先需要声明的是“语法糖”这个词绝非贬义词,它可以给我带来方便,是一种便捷的写法,编译器会帮我们做转换:而且可以提高开发编码的效率,在性能上也不会带来损失.这让java开发人员羡慕不已,呵呵. 1. ...