触发器oracle使用,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、行级触发器

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值