加入收藏 | 设为首页 | 会员中心 | 我要投稿 衡阳站长网 (https://www.0734zz.cn/)- 数据集成、设备管理、备份、数据加密、智能搜索!
当前位置: 首页 > 站长百科 > 正文

oracle11g – 如何捕获ORA-02055,“分布式更新操作失败;需要回滚

发布时间:2021-01-15 20:20:00 所属栏目:站长百科 来源:网络整理
导读:在一个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引发了错误消息“分布式更新操作失败;需要回滚”,因为现在有一个事务需要先回滚,然后才能引发以下错误.

在我的调试中,我没有看到完整的信息,这些信息会让我朝着正确的方向前进.

(编辑:衡阳站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读