主页 > 知识库 > ORACLE PL/SQL 触发器编程篇介绍

ORACLE PL/SQL 触发器编程篇介绍

热门标签:服务外包 百度竞价排名 地方门户网站 网站排名优化 Linux服务器 铁路电话系统 呼叫中心市场需求 AI电销
1.基本概念
两种功能:完成由数据库的完整性约束难以完成的复杂业务规则的约束;监视数据库的各种操作,实现审计功能。
触发器分为:DML触发器(对表或视图执行DML操作时触发),INSTEAD OF触发器(只定义在视图上,替代实际的操作语句),系统触发器(对数据库系统进行操作时触发,如DDL语句、启动或关闭数据库等)
触发事件: 上述触发器中括号内容都是触发事件。
触发条件: WHEN子句
触发对象:包括表、视图、模式、数据库。
触发操作:触发器自动执行的程序。
触发时机:触发器相对操作执行的时间,BEFORE/AFTER
条件谓词:INSERTING(触发器事件为INSERT时为真),UPDATING,DELETING
触发子类型:行触发和语句触发,触发中的new和old表。
2.创建触发器
复制代码 代码如下:

CREATE OR REPLACE TRIGGER触发器名>

触发条件
触发体
复制代码 代码如下:

CREATE TRIGGER my_trigger --定义一个触发器my—trigger
BEFORE INSERT or UPDATE of TID,TNAME on TEACHERS
FOR each row
WHEN(new.TNAME='David') --这一部分是触发条件
DECLARE --下面这一部分是触发体
teacher_id TEACHERS.TID%TYPE;
INSERT_EXIST_TEACHER EXCEPTION;
BEGIN
SELECT TID INTO teacher_id
FROM TEACHERS
WHERE TNAME=new.TNAME;
RAISE INSERT_EXIST_TEACHER;
EXCEPTION --异常处理也可用在这里
WHEN INSERT_EXIST_TEACHER THEN
INSERT INTO ERROR(TID,ERR)
VALUES(teacher_id,'the teacher already exists!');
END my triqqer;

3.执行触发器
自动执行
复制代码 代码如下:

CREATE TRIGGER my_trigger1
AFTER INSERT or UPDATE or DELETE on TEACHERS
FOR each row;
DECLARE
info CHAR(10);
BEGIN
IF inserting THEN --如果进行插入操作
info:='INSERT';
ELSIF updating THEN --如果进行修改操作
info:='Update';
ELSE--如果进行删除操作
info:='Delete';
END IF;
INSERT INTO SQL_INFO VALUES(info); --记录这次操作信息
END my_trigger1;

4.删除触发器
复制代码 代码如下:

DROP TRIGGER my_trigger;
您可能感兴趣的文章:
  • oracle 触发器 学习笔记
  • Oracle触发器用法实例详解
  • Oracle创建主键自增表(sql语句实现)及触发器应用
  • oracle监控某表变动触发器例子(监控增,删,改)
  • [Oracle] 如何使用触发器实现IP限制用户登录
  • oracle 存储过程和触发器复制数据
  • Oracle 触发器的使用小结
  • SqlServer实现类似Oracle的before触发器示例
  • Oracle触发器trigger详解
  • Oracle中触发器示例详解

标签:仙桃 崇左 湖南 湘潭 铜川 黄山 兰州 衡水

巨人网络通讯声明:本文标题《ORACLE PL/SQL 触发器编程篇介绍》,本文关键词  ;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 收缩
    • 微信客服
    • 微信二维码
    • 电话咨询

    • 400-1100-266