杭州Java培训
达内杭州Java培训中心

15268258619

热门课程

达内讲解ORACLE PL/SQL 触发器编程

  • 时间:2016-03-23
  • 发布:杭州java培训
  • 来源:达内新闻


    杭州达内java培训专家简单说一下ORACLE PL/SQL 触发器的相关知识。

    ORACLE PL/SQL 触发器能够完成由数据库的完整性约束难以完成的复杂业务规则的约束;监视数据库的各种操作以及实现审计功能 。

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字段自增
下一篇:达内java培训:解析Oracle中多表级联删除

恭喜达内获得《产学合作协同育人项目合作伙伴奖》

中传学子参加达内Java培训,转身成为Java工程师月薪12.5K

达内教育总裁韩少云受邀出席GIE国际教育峰会做主题演讲

学员参加达内网络营销培训,获10万年薪入职微众传媒

选择城市和中心
贵州省

广西省

海南省