oracle程序包编译后怎么回退,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;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值