有时异常返回如下:“ORA-06502:PL / SQL:numeric或value error:
字符串缓冲太小“。
字符串缓冲太小“。
它不是可读的,因为它不会报告表,列和它尝试写入的值。
在发生或捕获异常的时刻获取当前的过程名称将是有用的。
我该如何获得?
你可能想要
DBMS_UTILITY.FORMAT_ERROR_BACKTRACE
功能
SQL> ed Wrote file afiedt.buf 1 create or replace procedure p1 2 is 3 begin 4 raise_application_error( -20001,'Error 1',true ); 5* end; SQL> / Procedure created. SQL> create or replace procedure p2 2 as 3 begin 4 null; 5 p1; 6 end; 7 / Procedure created. SQL> begin 2 p2; 3 exception 4 when others then 5 dbms_output.put_line( dbms_utility.format_error_backtrace ); 6 end; 7 / ORA-06512: at "SCOTT.P1",line 4 ORA-06512: at "SCOTT.P2",line 5 ORA-06512: at line 2 PL/SQL procedure successfully completed.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。