1. Lära sig
  2. /
  3. Courses
  4. /
  5. SQL Server におけるトランザクションとエラー処理

Connected

exercise

TRY...CATCH 構造での @@TRANCOUNT の確認

口座 10 の名義人が抽選に当選し、$200 を受け取ります。口座 10 の current_balance にその $200 を加算するためのシンプルなスクリプトを用意しました。正しく書けたつもりですが、念のためコードを確認したいと思います。

実は、入金処理でうっかりミスをしています: SET current_balance = 'current_balance' + 200。'current_balance' を文字列で書いてしまい、エラーになります。

作成するスクリプトは、エラーが発生した場合に未完了の変更をすべて ROLLBACK するようにし、オープンなトランザクションがあるかを確認してください。すべて正常に実行された場合は、トランザクションを COMMIT します。その際もオープンなトランザクションがあるかを確認してください。

Instruktioner

100 XP
  • トランザクションを開始します。
  • 演算のミスを修正します。
  • TRY ブロック内で、トランザクションがあるかを確認してから COMMIT します。
  • CATCH ブロック内で、トランザクションがあるかを確認してから ROLLBACK します。