在触发器中加入:pragma autonomous_transaction;(在DECLARE后面) 表示是自由事务处理。
如:
CREATE OR REPLACE TRIGGER TRIG_INTEGRITY_T1
before insert or update on T1
for each row
DECLARE
PRAGMA AUTONOMOUS_TRANSACTION;
BEGIN
pro_xd_gqzr_cbqk; --需要执行的存储过程名称
COMMIT;
END;
在正常情况下,Oracle规定在触发器中不能运行 DDL(即Create/Alter/Drop)语句和Commit/Rollback语句的,因为DDL操作是隐性提交的,在触发器不允许有Commit,如在触发器中加入DDL语句,这种隐性提交就会导致错误信息;但有时特殊情况下需要在触发器中使用DDL语句,这时怎么办。
可以采取以下的解决办法:
通过以上方法即可解决触发器中不能有DDL语句的问题!
一: 在触发器中使用DDL语句。 如 drop table t1 ,触发的时候会报错,
ORA-04092: cannot COMMIT in a trigger,因为DDL语句隐含commit。