019 例外と例外処理(カスタム例外処理戦略) 029 問題

問題

データベースにデータを挿入するプログラムを作成してください。挿入しようとするデータが既存のデータと競合する場合、DataIntegrityViolationException をスローしてください。

ヒント


データベースにデータを挿入するプログラムを作成する際に、データの重複や競合を検知して DataIntegrityViolationException をスローするためには、以下のポイントに注意してください。

  1. ユニークなキーの制約を利用する: データベースにユニークなキーの制約(Primary Key や Unique 制約)を設定し、これに違反する挿入を防ぎます。
  2. トランザクションの使用: データの挿入はトランザクション内で行い、トランザクションのコミット前に既存データとの競合を確認します。トランザクション内でのエラーはトランザクション全体をロールバックさせることができます。
  3. エラーハンドリング: データ挿入時にデータベースエラーが発生した場合、それが DataIntegrityViolationException に該当するエラーであるかどうかを判定し、該当する場合にのみ例外をスローします。

これらのポイントを考慮して、データベースにデータを挿入するプログラムを実装してください。

解答例

「019 例外と例外処理」問題集リスト