PL/SQL 触发器简介
与公司同事交流了一下,得知触发器很少用。性能是一方面,主要是如果用太多触发器,可能到时你都不知道会有什么操作自动发生。
有些操作可以在程序中控制。例如在插入某个表时,写个log表的记录。这可以用触发器实现,但比较好的做法还是在程序中写个插入到log的语句实现。
所以,就只学习了很简单的部分。
触发器的通用语法如下:
CREATE [OR REPLACE] TRIGGER Trigger_name
{BEFORE | AFTER } {INSERT | DELETE | UPDATE} ON TABLE_NAME
[FOR EACH ROW]
[FOLLOWS another_trigger]
[ENABLE | DISABLE]
[WHEN condition]
DECLARE
BEGIN
END;
注意触发器的body是一个代码块,中间不用IS或AS连接。
触发器体包括伪记录:NEW和:OLD,分别表示将要从内存中读出处理的记录和将要被处理的记录。对INSERT来说,:NEW表示要插入的记录,没有:OLD。其他的不再赘述。但是在触发器头的WHEN条件中,:NEW和:OLD要将前面的冒号:去掉。
默认的触发器是语句级的,加了FOR EACH ROW之后就变成行级的。
一般来说,触发器是基于表的。可以使用INSTEAD OF触发器来修改视图,但不建议这么做。因为修改视图可能会修改到底层的表,造成误操作什么的。
目前见过的触发器的使用,是在插入到表前,判断:NEW的主键值是不是为空,如果是则填充(使用SEQUENCE),例如下例:
create or replace trigger t_gkey
before insert on example
for each row
begin
if :NEW.gkey is null or :NEW.gkey = 0 then --可对新记录判断
:NEW.gkey := s_gkey.nextval --如果主键不符合要求,可对新记录操作
end if;
exception
when others then raise_application_error(-20000,'Trigger t_gkey Error');
end;
理论上可以有12个类型的触发器。
BEFORE | AFTER
INSERT | DELETE | UPDATE
FOR EACH ROW | FOR EACH STATEMENT
请自由组合。
有三个布尔函数,INSERTING, DELETING, UPDATING。用来标示当前事件(相应的布尔函数的值为TRUE,否则为FALSE)。
在DML语句失败的情况下,主事务会回滚,触发器产生的事务也跟着回滚。如果不想回滚触发器产生的事务,可将其设置为自治事务。
语法为在Declare中添加PRAGMA AUTONOMOUS_TRANSACTION;并在最后添加COMMIT;
create or replace trigger t_gkey
before insert on example
for each row
declare
pragma autonomous_transaction; --添加
begin--可能本例不太正确,但语法是这样没错啦
if :NEW.gkey is null or :NEW.gkey = 0 then --可对新记录判断
:NEW.gkey := s_gkey.nextval --如果主键不符合要求,可对新记录操作
end if;
commit;--添加
exception
when others then raise_application_error(-20000,'Trigger t_gkey Error');
end;
不要花太多时间在触发器上,那不是最重要的。
PL/SQL 触发器简介的更多相关文章
- Oracle数据库之PL/SQL程序设计简介
PL/SQL程序设计简介 一.什么是PL/SQL? PL/SQL是 Procedure Language & Structured Query Language 的缩写. ORACLE的SQL ...
- [推荐]ORACLE PL/SQL编程详解之一:PL/SQL 程序设计简介(千里之行,始于足下)
原文:[推荐]ORACLE PL/SQL编程详解之一:PL/SQL 程序设计简介(千里之行,始于足下) [推荐]ORACLE PL/SQL编程详解之一: PL/SQL 程序设计简介(千里之行,始于足下 ...
- Oracle数据库之PL/SQL触发器
Oracle数据库之PL/SQL触发器 1. 介绍 触发器(trigger)是数据库提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是 ...
- ORACLE数据库之PL/SQL触发器、rownum、动态SQL、数据库之视图与索引
WHEN子句说明触发约束条件.Condition为一个逻辑表达时,其中必须包含相关名称,而不能包含查询语句,也不能调用PL/SQL函数.WHEN子句指定的触发约束条件只能用在BEFORE和AFTER行 ...
- PL/SQL编程基础(一):PL/SQL语法简介(匿名PL/SQL块)
PL/SQL PL/SQL是Oracle在关系数据库结构化查询语言SQL基础上扩展得到的一种过程化查询语言. SQL与编程语言之间的不同在于,SQL没有变量,SQL没有流程控制(分支,循环).而PL/ ...
- ORACLE PL/SQL:触发器
ORACLE PL/SQL 触发器 本篇主要内容如下: 8.1 触发器类型 8.1.1 DML触发器 8.1.2 替代触发器 8.1.3 系统触发器 8.2 创建触发器 8.2.1 触发器触发次序 8 ...
- Oracle学习笔记十 使用PL/SQL
PL/SQL 简介 PL/SQL 是过程语言(Procedural Language)与结构化查询语言(SQL)结合而成的编程语言,是对 SQL 的扩展,它支持多种数据类型,如大对象和集合类型,可使用 ...
- 每周一书《Oracle 12 c PL(SQL)程序设计终极指南》
本周为大家送出的书是<Oracle 12 c PL(SQL)程序设计终极指南>,此书由机械工业出版社出版, 孙风栋,王澜,郭晓惠 著. 内容简介: <Oracle 12c PL/SQ ...
- Oracle PL/SQL
PL/SQL 简介 PL/SQL 是过程语言(Procedural Language)与结构化查询语言(SQL)结合而成的编程语言,是对 SQL 的扩展,它支持多种数据类型,如大对象和集合类型,可使用 ...
随机推荐
- websphere性能设置和日常维护
一. 确认磁盘空间是否满足要求1. WebSphere 应用服务器自身代码的占用空间.这个空间一般在1G左右,在不同的系统平台上略有差异. 2. 概要文件所占的空间.WebSphere应用服务器V6. ...
- Immutable Object模式
多线程共享变量的情况下,为了保证数据一致性,往往需要对这些变量的访问进行加锁.而锁本身又会带来一些问题和开销.Immutable Object模式使得我们可以在不使用锁的情况下,既保证共享变量访问的线 ...
- 【POJ2778】AC自动机+矩阵乘法
DNA Sequence Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 14758 Accepted: 5716 Descrip ...
- squid透明代理+iptables防火墙,多网卡详细配置
squid透明代理+iptables防火墙详细配置 看到很多人都在不停地问iptables+squid做透明代理的问题,鄙人不才,斗胆在此做统一解答.如有任何纰漏还望各位批评指教. ========= ...
- 分布式文件系统FastDFS安装与配置(单机)
安装包如下:fastdfs-nginx-module_v1.16.tar.gzFastDFS_v5.05.tar.gzlibfastcommon-master.zipnginx-1.8.0.tar.g ...
- 【转】蓝牙物理链路类型:SCO和ACL链路
原文网址:http://blog.chinaunix.net/uid-23193900-id-3272233.html 蓝牙物理链路ACL(Asynchronous Connectionless), ...
- dotfuscator使用方法
dotfuscator如何对.net程序进行混淆保护对于程序代码的保护,网上有很多资料,有的说混淆,有的说加密,我比较支持混淆的方法,这样可以让反编译劳工,头晕一阵子,哈哈开玩笑.对于加密如果不是不得 ...
- POJ --2104
K-th Number Time Limit: 20000MS Memory Limit: 65536K Total Submissions: 34935 Accepted: 11134 Ca ...
- Android学习笔记(四)深入探讨Activity
在应用程序中至少包含一个用来处理应用程序的主UI功能的主界面屏幕.这个主界面一般由多个Fragment组成,并由一组次要Activity支持.要在屏幕之间切换,就必须要启动一个新的Activity.一 ...
- C语言实现两栈空间共享
一个同学让我改一段两栈共享的C语言代码,实现进栈.出栈.输出栈里元素的功能. 代码如下: #include <stdio.h> #include <stdlib.h> #def ...