当前位置 : 主页 > 编程语言 > java >

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

来源:互联网 收集:自由互联 发布时间:2022-07-04
for tab_name in tables loop execute immediate 'drop table '||tab_name; --此处可能会报错end loop; 当前情况是,循环表,进行删除,如果出现表不存在,则会异常中断,导致整个存储过程挂掉,需求是要
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)

  

上一篇:linux运行sh文件提示 permission denied
下一篇:没有了
网友评论