ここから本文です

sqlのエラーハンドリングについて質問です。

ggs********さん

2012/1/2312:30:07

sqlのエラーハンドリングについて質問です。

シェルからsqlplusを実行し、そのsqlplusで発生したエラーをハンドリングするために、
出力内容をORACLEエラーコード(ORA-xxxxx)、SQLPLUSエラーコード(SP2-xxxxx)
で検索して判定しています。


また、SQLで何らかのエラーが発生した際に処理を終了させるために、
SQL実行前に
whenever sqlerror exit;
whenever oserror exit;
を定義しています。

何らかのエラーが発生した際は、ORACLEエラーコード(ORA-xxxxx)、SQLPLUSエラーコード(SP2-xxxxx)
が出力されるため、エラーハンドリングは可能と考えているのですが、
sqlplusのstartコマンドでsqlファイルを実行した場合のみ、エラーコードが出
力されないため、ハンドリングできません。

■実行例
SQL> start 存在しないsqlファイル
O/Sメッセージ:No such file or directory
切断しました。


試しにwhenever oserror exit;の記述を削除したところ
SP2-0130が出力されエラーハンドリングできました。

whenever oserror exit;
の記述があるとエラーコードが出力されないのはなぜでしょうか??

補足spoolコマンドで試してみたところ
whenever oserrorが定義されていても
SP2-0322
のメッセージは出力されるのです。。

start(@)コマンドだけ何か特別なのでしょうか??

閲覧数:
2,385
回答数:
1
お礼:
50枚

違反報告

ベストアンサーに選ばれた回答

the********さん

2012/1/2314:58:13

コードが間違ってるんじゃない?

この回答は投票によってベストアンサーに選ばれました!

みんなで作る知恵袋 悩みや疑問、なんでも気軽にきいちゃおう!

Q&Aをキーワードで検索:

Yahoo! JAPANは、回答に記載された内容の信ぴょう性、正確性を保証しておりません。
お客様自身の責任と判断で、ご利用ください。
本文はここまでです このページの先頭へ

「追加する」ボタンを押してください。

閉じる

※知恵コレクションに追加された質問は選択されたID/ニックネームのMy知恵袋で確認できます。

不適切な投稿でないことを報告しました。

閉じる