Oracle 之 触发器
触发器是特定的事件出现的时候,自动隐式执行代码块,这个过程用户无法控制,用户只能控制触发的事件,触发后的操作,触发过程是自动执行的。
定义触发器:
1、名称
2、触发时间:是在执行事件之前(before)触发,还是之后(after)触发
3、事件:insert(插入)、delete(删除)、update(更新)
4、作用目标:on table_name
5、引用的值:old(旧值)、new(新值)
6、作用域:for each row(行级)或 无此行表示语句级
7、约束条件:可选,where 约束条件,不能包含查询语句,也不能调用PL/SQL函数
8、主体语句:begin ...
示例:create or replace trigger biufer_employess_emp_id
before insert or update of emp_id on employees
referencing old as old_value new as new_value
for each row
when (new_value.emp_id =9)
begin
:new_value.age :=26;
end biufer_employess_emp_id;
当执行下面SQL语句时触发器被触发:
INSERT INTO employees(emp_id,emp_name,position,age,address)
VALUES(9,'周迅','开发工程师',NULL,'南京路99号');
触发器自动执行,不会通知用户,再次查看employees表时:
9 周迅 开发工程师 26 南京路99号
但此时触发器不会提交,触发器里也不能使用commit/rollback/DDL语句,只能由用户提交(或其他程序)
触发器类型
1、语句触发器
在表上或者某些情况下的视图上执行的特定语句或者语句组的触发器。能够与insert、delete、update或者组合上进行关联。但无论使用什么样的组合,各个语句触发器都只会针对指定语句激活一次。比如,无论update多少行,也只会调用一次update语句触发器。
示例:需要对表进行DML的用户进行安全检查,看是否具有合适的特权。
create table foo(a number);
create trigger biud_foo
before insert or update or delete on foo
begin
if user not in ('donny') then
raise_application_error(-20001,'You don"t have access to modify this table. ');
end if;
end; //即使sys,system用户也不能修改foo表
2、行触发器
是指为受到影响的各个行激活的触发器。
示例:为主键生成自增序列号
create table foo(id number,data varchar2(20));
create sequence foo_seq;
create or replace trigger bifer_foo_pk
before insert on foo
for eache row
begin
select foo_seq.nextval into :new.id from dual;
end
SQL语句
insert into foo(data) values('donny');//自动添加id值
insert into foo values(5,'chen'); //插入该行5会被替换成foo_seq.nextval生成的值
select *from foo;
3、instead of 触发器
create or replace view company_name as select emp_id,emp_name,position,age,address from scctt.employess;
update company_name set emp_name = 'tom' where emp_id = 13;
create or replace trigger update_name_company_name
instead of update on company_name
begin
update employess set emp_id := :new.emp_id,
emp_name := :new.emp_name,
where employess_id = :old.emp_id;
end;
4、系统条件触发器
系统事件:数据库启动、关闭,服务器错误
create trigger ad_startup after startup on database
begin
---do some stuff
end;
5、用户事件触发器
用户事件:用户登录、注销,create/alter/drop/analyze/audit/grant/revoke/rename/trancate/logoff
示例:记录删除对象
create table drop_object(obj_name varchar2(30),obj_type varchar2(30),dropped_on date); //日志表
create or replace trigger log_drop_trigger // 触发器
before drop on donny.schema
begin
insert into drop_object values(ora_dict_obj_name,ora_dict_type,sysdate);
end;
SQL语句:
create table drop_me(a number);
create view drop_me_view as select *from drop_me;
drop view drop_me_view;
drop table drop_me;
select *from droped_objects
禁用和启用触发器
alter trigger <trigger_name> disable;
alter trigger <trigger_name> enable;
触发器的作用
1、允许/限制对表的修改
2、自动生成派生列,比如自增字段。
3、强制数据一致性。
4、提供审计和日志记录
5、防止无效的事务处理
6、启用复杂的业务逻辑
Oracle 之 触发器的更多相关文章
- Oracle数据库——触发器的创建与应用
一.涉及内容 1.理解触发器的概念.作用和类型. 2.练习触发器的创建和使用. 二.具体操作 (实验) 1.利用触发器对在scott.emp表上执行的DML操作进行安全性检查,只有scott用户登录数 ...
- [结]Oracle trigger(触发器)摘录
1.触发器: 是许多关系数据库系统都提供的一项技术.在ORACLE系统里,触发器类似过程和函数,都有声明,执行和异常处理过程的PL/SQL块. 触发器在数据库里以独立的对象存储,它与存储过程和函数不同 ...
- oracle的触发器
oracle的触发器分为语句级和行级两种类型,在视图上所创建的触发器叫做什么类型的触发器? DML触发器有三类: 1, insert触发器: 2, update触发器: 3, delete触发器: 触 ...
- oracle中触发器的讲解
触发器在数据库里以独立的对象存储,它与存储过程和函数不同的是,存储过程与函数需要用户显示调用才执行,而触发器是由一个事件来启动运行.即触发器是当某个事件发生时自动地隐式运行.并且,触发器不能接收参数. ...
- MYSQL和ORACLE的触发器与存储过程语法差异
整改了一番脚本,遇到了一些两种数据库之间的差异,记录一下: 触发器: 差异 MYSQL ORACLE 说明 创建语句不同 create trigger `AA` BEFORE INSERT on `B ...
- Oracle - java创建Oracle 的触发器
Oracle - java创建Oracle 的触发器 今天碰到这个问题,遇到点问题,到这来 总结一下解决的办法, 需求,为一个用户当中的表增加一个自动增长列,我还没有学Oracle 的这部分,只是简单 ...
- oracle之触发器
触发器可以看做一种"特殊"的存储过程,它定义了一些与数据库相关事件(如INSERT,UPDATE,CREATE等事件)发生时应执行的"功能代码块",常用与管理复 ...
- oracle数据库触发器(trigger)用法总结
from:http://blog.csdn.net/zhanzhib/article/details/48729417 触发器的意思就是当我们对数据库对象(一般是表或视图)进行insert.updat ...
- Oracle中用触发器实现自动记录表数据被修改的历史信息
oracle中用触发器实现自动记录表数据被修改的历史信息. 有一些比较重要的表字段每次修改需要做历史记录,以后可以查询这个表中某些字段如何被修改过.由什么改成了什么等,由谁操作,操作时间等. 实例:1 ...
- Oracle使用触发器和mysql中使用触发器的比较——学习笔记
一.触发器 1.触发器在数据库里以独立的对象存储, 2.触发器不需要调用,它由一个事件来触发运行 3.触发器不能接收参数 --触发器的应用 举个例子:校内网.开心网.facebook,当你发一个日志, ...
随机推荐
- 代码实现:两个乒乓球队进行比赛,各出三人。甲队为a,b,c三人,乙队为x,y,z三人。 已抽签决定比赛名单。有人向队员打听比赛的名单。 a说他不和x比,c说他不和x,z比,请编程序找出三队赛手的名单
/*两个乒乓球队进行比赛,各出三人.甲队为a,b,c三人,乙队为x,y,z三人. 已抽签决定比赛名单.有人向队员打听比赛的名单. a说他不和x比,c说他不和x,z比,请编程序找出三队赛手的名单.*/ ...
- pip安装selenium时,报错“You are using pip version 10.0.1, however version 18.0 is available.”的问题
pip安装selenium,pip install selenium 类型这样错误 1 原因可能不是以管理员身份运行cmd安装selenium 2 解决方式 也是要管理员身份运行 重点在最后一句 ...
- ES6的对象属性简写
在ES6中允许我们在设置一个对象的属性的时候不指定属性名. 不使用ES6: const name='Ming', age='18', city='Shanghai'; const student ={ ...
- 页面访问过程及get/post的理解——
Chrome查看开发者工具面板,常看的一些数据? Elements:查找网页源代码HTML中的任一元素,手动修改任一元素的属性和样式且能实时在浏览器里面得到反馈. Console:记录开发者开发过程中 ...
- jdbc 对sqlite的基本操作
1.向数据库中创建表 public void addTable( String dbpath) { //创建表单的sql语句 String createtablesql= " CREATE ...
- 浅谈Excel开发:二 Excel 菜单系统(转)
编辑器加载中...http://www.cnblogs.com/yangecnu/p/Excel-Menu-System-Introduction.html 在开始Excel开发之前,需要把架子搭起来 ...
- 如图 honehoneclock
如图人体时钟 honehoneclock 页面演示来自http://chabudai.org/blog/?p=59 <embed name="honehoneclock" ...
- JavaScript Source Maps浅析
阅读目录 有用的链接 Link: 原文链接 译文开始: 对网站进行性能优化对一个最容易的方法就是把JS和CSS进行打包压缩.但是当你需要调试这些压缩文件中的代码的时候,会发生什么?可能会是一场噩梦.但 ...
- Day01:对象和类(上)
对象的概念 Java 是面向对象的编程语言,对象就是面向对象程序设计的核心.所谓对象就是真实世界中的实体,对象与实体是一一对应的,也就是说现实世界中每一个实体都是一个对象,它是一种具体的概念.对象有以 ...
- TCP中三次挥手四次握手
1.TCP连接 手机能够使用联网功能是因为手机底层实现了TCP/IP协议,可以使手机终端通过无线网络建立TCP连接.TCP协议可以对上层网络提供接口,使上层网络数据的传输建立在“无差别”的网络之上. ...