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

网友投稿 1057 2022-11-06 10:10:53

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

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

end loop;

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

最终代码:

for tab_name in tables loop beginexecute 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); ENDsqlcode是异常编号,sqlerrm是异常的详细信息,如果异常信息太多,可以截取一段显示,如 DBMS_OUTPUT.put_line(‘sqlerrm : ’ ||substr(sqlerrm,1,100));是截取前100个字符显示出来。也可以插入到日志表insert xxx values (sqlcode,sqlerrm)

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:mysql函数find_in_set() 、like、locate()、in的使用与区别
下一篇:Mybatis实现oracle批量插入及分页查询
相关文章