トランザクションT1がある行Xを読んだ後、別のトランザクションT2が行Xの値を更新してコミットし、再びトランザクションT1行Xを読むと、以前読んだ値と異なる結果が得られた。 この現象を回避するSQLの隔離性水準のうち、最も水準の低いものはどれか。
ア | READ COMMITTED |
イ | REAF UNCOMMITTED |
ウ | REPEATABLE READ |
エ | SERIALIZABLE |
答え ウ
【解説】
ア | READ COMMITTEDは、コミットされたデータを読込むためダーティリードを回避できますが、2回目の読込みの列値が1回目と同じとは限りません。(×) |
イ | READ UNCOMMITTEDは、他のトランザクションがコミットしていないデータを読込むため、ダーティリードが発生します。(×) |
ウ | REPEATABLE READは、一つのトランザクション中で、対象の表のある行を2回以上参照する場合、1回目の読込みの列値と2回目以降の読込みの列値が同じであることが保証されます。(〇) |
エ | SERIALIZABLEは、全てのトランザクションを直列化することです。(×) |
【キーワード】
・隔離性水準