忍者ブログ
情報処理技術者試験の合格を目指す全受験者のための、1問1問「徹底解説」ブログです。単なる過去問の暗記ではなく、なぜその答えになるのかを本質的に理解できるよう解説します。書籍などでは学べない最新用語やトレンドを踏まえてご紹介します。

【データベース】実務のデファクトスタンダード!「Read Committed」|情報処理問題1000本ノック

データの安全性とシステムの処理速度。その2つが最も実用的なバランスで妥協(トレードオフ)した、実務で最頻出の分離レベル「Read Committed」を攻略しましょう。

1. 【 問題 】:トランザクション分離レベルの識別

【 問題 】 ANSI/ISOで定義されている4段階のトランザクション分離レベルのうち、他のトランザクションがコミット(確定)していない未確定の変更データの読み取り(ダーティリード)は防止されるが、自身の処理中に他のトランザクションがデータを更新・追加することによって発生する「ノンリピータブルリード」および「ファントムリード」の発生は許容されるものはどれでしょうか?

① Read Uncommitted (未コミット読み取り)
② Read Committed (コミット済み読み取り)
③ Repeatable Read (反復可能読み取り)
④ Serializable (直列化可能)

2. 正解:

正解: ② Read Committed(コミット済み読み取り)

3. 解説:「確定した事実」だけを信じる世界

Read Committedは、名前の通り「コミット(確定)されたデータだけを読み取る」というルールです。これにより、存在しない幻のデータを読んでしまう最悪の事態(ダーティリード)は100%防げます。

【なぜ他の2つの現象は起きてしまうのか?】

■ ノンリピータブルリードが起きる理由
・自分が1回目の読み込みをした後、他のトランザクションがデータを変更してコミットを完了したとします。
・Read Committedのルールは「コミットされたら読んでも良い」なので、自分が2回目の読み込みをすると、他人が確定させた最新の値(書き換わった後の値)が見えてしまいます。これが「同じ処理の中で、2回同じ場所を読んだのに値が変わってしまう(ノンリピータブルリード)」の原因です。

■ ファントムリードが起きる理由
・同様に、自分が検索した後に他人が新しいデータを挿入してコミットを完了すると、2回目の検索では、1回目には存在しなかったはずの「新しい行(ファントム)」が出現してしまいます。
[ 4段階のレベルと不整合の対応関係 ]
1. Read Uncommitted = 【全て発生】(最速・最危険)
2. Read Committed【ダーティ防止、残り2つは発生】(実務の標準) ← ココ!
3. Repeatable Read = 【ダーティ・ノンリピ防止、ファントムのみ発生】
4. Serializable = 【全て防止】(最堅牢・最遅)

1. 理解のコツ: 「オフィシャルの記者発表」をイメージしてください。まだ噂段階の未確定情報には一切耳を貸さず、公式発表(コミット)された情報だけを記事にするため、デマ(ダーティリード)を掴むリスクはありません。しかし、公式発表が朝と夕方で更新されれば、手元のニュース内容が変わる(ノンリピータブルリード)のは受け入れる、というスタンスです。
2. 試験対策の視点: 「ダーティリードは防ぐ(許容されない)」「ノンリピータブルリードとファントムリードは発生する(許容される)」という組み合わせが来たらRead Committedが一択です。多くのデータベースシステムでデフォルト(初期設定)に採用されているため、問題文での登場回数が圧倒的に多い最重要レベルです。


4. まとめ

「嘘のデータは読まないが、他人が確定させた最新の変化はそのまま受け入れる分離レベル」。これがRead Committedです。データの一貫性をある程度保ちつつ、データベースに余計なロック(待ち時間)をかけないため、大規模なアクセスを捌く現代のシステムにおいて最もバランスの良い設定とされています。


PR