oracle11g – 怎样捕捉ORA-02055,“漫衍式更新操纵失败;必要回滚
在一个Oracle处事器上的存储进程中,我实行将记录插入第二个Oracle处事器上的表中,但它失败,并呈现“漫衍式更新操纵失败;必要回滚”的非常 固然我的代码包括在BEGIN EXCEPTION END中,但错误处理赏罚措施无法捕捉错误. 我乃至把它扔进了第二个错误处理赏罚措施,没有任何结果.知道为什么我不能抓住这个错误.措施编译没有题目. 我的首要方针是捕捉错误,以便我可以向用户返回一些有效的对象.其它,我想尽也许找到错误的来源. 注1:假如我打消注释激发“长途错误”的行,则按预期捕捉. 留意2:与长途处事器的毗连是靠得住的,由于我可以毫无题目地查询它. 两台处事器均为:Oracle Database 11g 11.2.0.3.0版 – 64位出产版 BEGIN begin --raise_application_error( -20001,'Remote Error' ); insert into RemoteSchema.RemoteObject@RemoteSystem (field_one,field_two) select value_one,value_two from dual; exception when others then raise_application_error( -20000,'Remote Error:' || sqlerrm ); end; exception when others then raise_application_error( -20000,'Caught Remote Error:' || sqlerrm ); end; 办理要领颠末更多的调试,一位同事辅佐我发明白题目.错误动静令人狐疑,由于更新现实上是乐成的,但乐成意味着此刻有一个带有“漫衍式更新”的勾当事宜.当我的代码碰着后续的微不敷道的错误时,Oracle激发了错误动静“漫衍式更新操纵失败;必要回滚”,由于此刻有一个事宜必要先回滚,然后才气激发以下错误. 在我的调试中,我没有看到完备的信息,这些信息会让我朝着正确的偏向提高. (编辑:湖南网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |