web-dev-qa-db-ja.com

Oracle PL / SQL:スタックトレース、パッケージ名、およびプロシージャ名を取得する方法

時々、例外は「ORA-06502:PL/SQL:数値または値のエラー:文字列バッファが小さすぎます」のようなものを返します。

書き込もうとしたテーブル、列、値のいずれもレポートしないため、それほど読みやすくありません。

例外が発生またはキャッチされた時点で現在のプロシージャ名を取得すると便利です。

どうすれば入手できますか?

24
Revious

おそらく 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.
38
Justin Cave
9
xmedeko

DBMS_UTILITY.FORMAT_ERROR_STACKDBMS_UTILITY.FORMAT_ERROR_BACKTRACE の組み合わせを使用します。 (ジャスティン洞窟の答えを改善する)

when others then
  Dbms_Output.put_line ( DBMS_UTILITY.FORMAT_ERROR_STACK() );
  Dbms_Output.put_line ( DBMS_UTILITY.FORMAT_ERROR_BACKTRACE() );

これにより、最初の行にエラーが表示され、次の行にスタックが表示されます:(Justin Caveの例からの出力)

ORA-20001: Error 1
ORA-06512: at "SCOTT.X1", line 4
ORA-06512: at "SCOTT.X2", line 5
ORA-06512: at line 2
8
rvheddeg
7
mamboking