加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长百科 > 正文

oracle11g – 怎样捕捉ORA-02055,“漫衍式更新操纵失败;必要回滚

发布时间:2021-01-13 21:21:24 所属栏目:站长百科 来源:网络整理
导读:在一个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激发了错误动静“漫衍式更新操纵失败;必要回滚”,由于此刻有一个事宜必要先回滚,然后才气激发以下错误.

在我的调试中,我没有看到完备的信息,这些信息会让我朝着正确的偏向提高.

(编辑:湖南网)

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

    热点阅读