ORA-04091错误的处理
来源:互联网 发布:网络变压器引脚定义 编辑:程序博客网 时间:2024/05/29 17:53
有要求如下,一个工作序列表,如果flag字段被更新为OK,则将这条记录转移到log表中。
直接在触发器中,进行自身删除,报错:
ORA-04091: table AAA.AAAAAA is mutating, trigger/function may not see it
ORA-06512: at "AAA.TR_AAAAAA", line 4
ORA-04088: error during execution of trigger AAA.TR_AAAAAA'
后来参考了ASKTOM的文章,解决问题。
原文如下:
http://asktom.oracle.com/tkyte/Mutate/
思路就是在行级触发器中,将当前需要删除的行的rowid记录到pl/sql包的变量中,
然后在语句级的触发器中,将变量指向的行删除。
测试用的包和触发器如下: (共需两个,一个row level, 一个statement level)
create or replace package test_pkg is
type rowidArray is table of rowid index by binary_integer;
mRows rowidArray;
emtpy rowidArray;
end test_pkg;
/
create or replace trigger tr_aaaaaa
after update on aaaaaa
for each row
begin
if ('OK' = :new.flag) then
insert into aaaaaa_his(, , ,)
values(:new.,:new.,:new.,:new.);
test_pkg.mRows(test_pkg.mRows.count + 1) := :new.rowid;
end if;
end tr_aaaaaa;
/
create or replace trigger tr_aaaaaa_his
after insert on aaaaaa_his
begin
for i in 1 .. test_pkg.mRows.count loop
delete aaaaaa where rowid = test_pkg.mRows(i);
end loop;
test_pkg.mRows := test_pkg.emtpy;
end tr_aaaaaa_his;
/
测试通过。
- ORA-04091错误的处理
- ORA-12514错误的处理
- ORA-12516错误的处理
- ORA-12516错误的处理
- ORA-12516错误的处理
- Ora-12535错误的处理
- ORA-32004 的错误处理
- ORA-12516错误的处理
- ORA-32004 的错误处理
- 【故障处理】ORA-12162 错误的处理
- ORA-02396错误的处理办法
- Ora-00600 4194错误的处理过程
- weblogic ORA-03111错误的处理过程
- ORA-01455错误的处理方法
- ORA-12154: TNS错误的处理
- ORA-01779错误的处理方法
- ORA-00257 archiver error. 错误的处理
- Oracle ora-03113错误的处理
- 使用TCP协议的NAT穿透技术 (转)
- 自学中医入门必读
- 通过java查询数据库表结构
- Nginx 0.7.x + PHP 5.2.9(FastCGI)搭建胜过Apache十倍的Web服务器
- oracle 只取字符串中的数字
- ORA-04091错误的处理
- 业务场景和业务用例场景的区别(作者:Arthur网友)
- WCF从理论到实践(9):实例模式和对象生命周期
- 怎样学好中医,非常值的一读
- sc config、net-设置系统服务
- JavaScript String 对象参考手册
- MOTO 手机的UA
- 一个简单但很好用的线程锁
- 考试系统问题