2022年 秋期 データベーススペシャリスト 午前 問14

トランザクション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は、全てのトランザクションを直列化することです。(×)


キーワード
・隔離性水準

キーワードの解説
  • 隔離性水準
    他のトランザクションとの影響の度合いを示す指標で、3つの異常を定義しています。
    • ダーティリード
      コミットしていないデータを読むこと
    • アンリピータブルリード
      同じデータを複数回読むとき、結果が違うこと
    • ファントムリード
      異なるデータ集合を読んでしまうこと

もっと、「隔離性水準」について調べてみよう。

戻る 一覧へ 次へ