我有下面的触发器(mytrg),它调用一个过程(myproc),如果表1中有任何插入,该过程将更新表2。在表2中更新数据后,我在过程中有“COMMIT”语句。但是当 table1 中有插入时,我收到以下错误。
Error report:
SQL Error: ORA-04092: cannot COMMIT in a trigger
ORA-06512: at "myschema.myproc", line 63
ORA-06512: at "myschema.mytrg", line 2
ORA-04088: error during execution of trigger 'myschema.mytrg'
04092. 00000 - "cannot %s in a trigger"
*Cause: A trigger attempted to commit or rollback.
*Action: Rewrite the trigger so it does not commit or rollback.
**Trigger:**
create or replace
trigger mytrg
after insert on table1
for each row
begin
myschema.myproc(:new.ID, :new.NAME, :new.TYPE_CODE, :new.LANGUAGE);
end;
需要知道如何提交更新。
Thanks
触发器内不能有 COMMIT。一旦提交到 table1 的 INSERT,您的 UPDATE 就会被提交。
但为了实现你想要的,你可以使用自治事务。例如,
CREATE OR REPLACE TRIGGER mytrg
AFTER INSERT ON table1 FOR EACH ROW
DECLARE
PRAGMA AUTONOMOUS_TRANSACTION;
BEGIN
myschema.myproc(:new.ID, :new.NAME, :new.TYPE_CODE, :new.LANGUAGE);
COMMIT;
END;
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)