oracle11g – 如何捕获ORA-02055,“分布式更新操作失败;需要回滚
发布时间:2020-12-12 12:46:19 所属栏目:百科 来源:网络整理
导读:在一个Oracle服务器上的存储过程中,我尝试将记录插入第二个Oracle服务器上的表中,但它失败,并出现“分布式更新操作失败;需要回滚”的异常 虽然我的代码包含在BEGIN EXCEPTION END中,但错误处理程序无法捕获错误. 我甚至把它扔进了第二个错误处理程序,没有任
在一个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引发了错误消息“分布式更新操作失败;需要回滚”,因为现在有一个事务需要先回滚,然后才能引发以下错误. 在我的调试中,我没有看到完整的信息,这些信息会让我朝着正确的方向前进. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |