在一个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;