oracle 触发器的使用

RAISE_APPLICATION_ERROR(-20000,'提示语');

其中:前一个参数的范围可以使用 -20999到-20000的随便一个,后一个参数是提示语言。

 

1、instead of 触发器的用法

在我们使用试图进行查询的时候,我们觉得使用起来很方便,因为需要使用的复杂sql语句,已经被定义为一个视图,从而很简单的就可以供大家使用,但在通过视图,对基表进行DML的时候,很多情况下是不能执行成功的,例如:

   CREATE OR REPLACE VIEW myview AS
     select a.empno, a.ename, b.deptno, b.dname
       from emp a, dept b
     where a.deptno = b.deptno;

  而当我们进行

    INSERT INTO MYVIEW VALUES (1,'1',1,'1');

  就会提示错误。

  此时,需要使用INSTEAD OF 触发器来实现。实现过程如下:

   CREATE OR REPLACE TRIGGER mytrigger

     INSTEAD OF INSERT ON myview

   BEGIN
    insert into dept(deptno,dname) values(:new.deptno,:new.dname);
    insert into emp(empno,ename,deptno) values (:new.empno,:new.ename,:new.deptno);
   END;

   测试:INSERT INTO MYVIEW VALUES (1,'1',1,'1');

   执行成功。

 

   注:此触发器不能应用于表,否则会报ora-25002:无法在表中创建INSTEAD OF触发器。

 

2、语句级触发器

3、行级触发器

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/10037372/viewspace-663250/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/10037372/viewspace-663250/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值