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/