Oracle   发布时间:2022-05-17  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了Oracle中触发器示例详解大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

前言

在ORACLE系统里,触发器类似过程和函数,都有声明,执行和异常处理过程的pl/sql块。

触发器类型

触发器在数据库里以独立的对象存储,它与存储过程和函数不同的是,存储过程与函数需要用户显示调用才执行,而触发器是由一个事件来启动运行。即触发器是当某个事件发生时自动地隐式运行。并且,触发器不能接收参数。所以运行触发器就叫触发或点火(firing)。OracLE事件指的是对数据库的表进行的INSERT、updatE及deletE操作或对视图进行类似的操作。OracLE将触发器的功能扩展到了触发OracLE,如数据库的启动与关闭等。所以触发器常用来完成由数据库的完整性约束难以完成的复杂业务规则的约束,或用来监视对数据库的各种操作,实现审计的功能。

开发中肯定会用到Oracle的触发器,本文进行详细讲解。

这里实例中用到的主要是Oracle中scott用户下的emp以及dept表,数据如下

Oracle中触发器示例详解

Oracle中触发器示例详解

一、触发器概念

1、概念:

触发器的本质是一个存储过程,顾名思义发生特定事件时Oracle会执行触发器中的代码。细分它的组成可以分为3个部分:第一部分在什么条件下触发器会执行,即触发器被触发的事件。第二部分在什么时间点执行触发器即触发器的发生事件例如before,after。第三部分触发器自身所要做的事情,就是触发器被触发以后具体想表达的事件,在begin和end之间的sql。

二、触发器的分类:

1、ddl触发器:即执行ddl操作后所触发的事件。

常用的ddl操作有:grant(授权),revoke(撤销授权),create(创建),drop(删除),alter(修改),comment(注释),audit(审核),rename(重命名)在进行具体实例以前先来讲解另一个概念:Oracle中的user和scheR_377_11845@a:

user:Oracle中的用户,拥有数据库的对象以及对数据库对象增删改查的权限。scheR_377_11845@a:该用户下所有数据库对象的集合Collection.类似于生活中房子scheR_377_11845@a和房子的拥有者user之间的关系,你是一个用户user你可以通过alter session查看别人的房子,但是你是否可以改变房子中的家具,要看这个房子的拥有者是否grant你这个权限,除非你是所有房子的最高权限人dba。

ddl Example:禁止scott用户的所有ddl操作

div class="codecode">
replaCE trigGER scott_trigger
BEFORE DDL
ON scheR_377_11845@A
BEGIN
 RAISE_APPliCATION_ERROR(-20008,'禁止scott用户的所有ddl操作');
END;

大佬总结

以上是大佬教程为你收集整理的Oracle中触发器示例详解全部内容,希望文章能够帮你解决Oracle中触发器示例详解所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: