問題
データベースにデータを挿入するプログラムを作成してください。挿入しようとするデータが既存のデータと競合する場合、DataIntegrityViolationException をスローしてください。
ヒント
データベースにデータを挿入するプログラムを作成する際に、データの重複や競合を検知して DataIntegrityViolationException をスローするためには、以下のポイントに注意してください。
- ユニークなキーの制約を利用する: データベースにユニークなキーの制約(Primary Key や Unique 制約)を設定し、これに違反する挿入を防ぎます。
- トランザクションの使用: データの挿入はトランザクション内で行い、トランザクションのコミット前に既存データとの競合を確認します。トランザクション内でのエラーはトランザクション全体をロールバックさせることができます。
- エラーハンドリング: データ挿入時にデータベースエラーが発生した場合、それが DataIntegrityViolationException に該当するエラーであるかどうかを判定し、該当する場合にのみ例外をスローします。
これらのポイントを考慮して、データベースにデータを挿入するプログラムを実装してください。
→解答例