I recently started working on a large complex application, and I've just been assigned a bug due to this error:
ORA-04091: table SCMA.TBL1 is mutating, trigger/function may not see it ORA-06512: at "SCMA.TRG_T1_TBL1_COL1", line 4 ORA-04088: error during execution of trigger 'SCMA.TRG_T1_TBL1_COL1'
The trigger in question looks like
create or replace TRIGGER TRG_T1_TBL1_COL1 BEFORE INSERT OR UPDATE OF t1_appnt_evnt_id ON TBL1 FOR EACH ROW WHEN (NEW.t1_prnt_t1_pk is not null) DECLARE v_reassign_count number(20); BEGIN select count(t1_pk) INTO v_reassign_count from TBL1 where t1_appnt_evnt_id=:new.t1_appnt_evnt_id and t1_prnt_t1_pk is not null; IF (v_reassign_count > 0) THEN RAISE_APPLICATION_ERROR(-20013, 'Multiple reassignments not allowed'); END IF; END;
The table has a primary key "
t1_pk", an "appointment event id"
t1_appnt_evnt_id and another column "
t1_prnt_t1_pk" which may or may
not contain another row's
It appears the trigger is trying to make sure that nobody else with the
referred to the same one this row is referring to a referral to another row, if this one is referring to another row.
The comment on the bug report from the DBA says "remove the trigger, and perform the check in the code", but unfortunately they have a proprietary code generation framework layered on top of Hibernate, so I can't even figure out where it actually gets written out, so I'm hoping that there is a way to make this trigger work. Is there?