ORACLE 存储过程异常捕获并抛出

 for tab_name in tables loop  
execute immediate 'drop table '||tab_name;  --此处可能会报错
 end loop;

当前情况是,循环表,进行删除,如果出现表不存在,则会异常中断,导致整个存储过程挂掉,需求是要能跳过错误的执行,不进行处理,进行下个循环。

 

最终代码:

 

 for tab_name in tables loop  
begin

execute immediate 'drop table '||tab_name;  --此处可能会报错

 EXCEPTION WHEN others THEN NULL;
end;

 end loop;

 

 

如何抛出

上面存储过程是,异常处理写法是(异常跳过不处理): 

EXCEPTION 
WHEN OTHERS THEN 
END

这种写法当存储过程抛出异常时,我们不知道其到底抛出了哪种异常(比如列宽度不够大而在插入数据时抛异常),可以按如下方式显示异常信息 

EXCEPTION 
WHEN OTHERS THEN 
DBMS_OUTPUT.put_line(‘sqlcode : ’ ||sqlcode); 
DBMS_OUTPUT.put_line(‘sqlerrm : ’ ||sqlerrm); 
END

sqlcode是异常编号,sqlerrm是异常的详细信息,如果异常信息太多,可以截取一段显示,如 
DBMS_OUTPUT.put_line(‘sqlerrm : ’ ||substr(sqlerrm,1,100));是截取前100个字符显示出来。
也可以插入到日志表
insert xxx  values (sqlcode,sqlerrm)

  

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值