9cubed
ブログ | Tailwind | Vite | Python | MariaDB | Node.js | Linux | PowerShell | Docker | Git | その他 | 将棋ウォーズ | 歌の練習
< 前の記事

排他ロック・共有ロック

次の記事 >

ギャップロック・ネクストキーロック

MariaDB

[MariaDB]トランザクション分離レベル

公開日:2026-01-06
更新日:2026-01-06

1. 概要

MySQL のトランザクション分離レベルについてです。
RDBMS の種類によって仕様が異なるので要注意。

2. 現在の設定の確認

コマンド
# グローバル
SELECT @@global.transaction_isolation;

# 現在のセッション(今回の接続のみ有効)
SELECT @@session.transaction_isolation;

コマンド
# グローバル
SET GLOBAL transaction_isolation = 'READ-COMMITTED';

# 現在のセッション(今回の接続のみ有効)
SET SESSION transaction_isolation = 'READ-COMMITTED';

3. 分離レベル

3.1 REPEATABLE READ(デフォルト)

トランザクションの中で SELECT した場合、最新データではなくスナップショットを見るため、スナップショット作成後は、他のトランザクションの変更による影響を受けない。
スナップショット作成のタイミングは、トランザクション開始時ではなく、最初に SELECT を実行した時のため、最初の SELECT では、他のトランザクションの変更を読み込む可能性がある。

3.2 READ COMMITTED

トランザクションの中で、他のトランザクションでコミットされたデータを読み込むことができる。
そのため、検索するタイミングによって結果が変わる(ノンリピータブルリード)。

3.3 READ UNCOMMITTED

他のトランザクションのコミットされていないデータを読み込むことができる(ダーティリード)。
これにより、開発環境などで、まだコミットされていないデータを外部から読み込んで確認することができる。

3.4 SERIALIZABLE

SELECT が自動的に SELECT ~ LOCK IN SHARE MODE 相当となり共有ロック(ネクストキーロック)される。
これにより、他のトランザクションで変更しようとすると、ロックが解除されるまで待機状態となるため、
ノンリピータブルリードやファントムリードが発生しない。

4. トランザクションで発生する現象

以下は、MySQL のデフォルトの分離レベル(REPEATABLE READ)では発生しません。
分離レベルを READ COMMITTED や READ UNCOMMITTED にした場合に発生します。

ダーティリード(Dirty Read)

コミットしていない変更内容を、他のトランザクションで読み込めてしまう。
READ UNCOMMITTED の場合のみ発生。

ノンリピータブルリード(Non-repeatable Read)

他のトランザクションの変更により、トランザクション内で同じ条件で検索しても、結果が変わってしまう。

ファントムリード(Phantom Read)

他のトランザクションの変更により、検索した時に行が増減したり、SUM() や COUNT() などの結果が増減してしまう。
< 前の記事

排他ロック・共有ロック

次の記事 >

ギャップロック・ネクストキーロック

YouTube X

新着一覧

  • テーブル結合(CROSS JOIN、INNER JOIN、LEFT JOIN)MariaDB
  • 楽観ロック・悲観ロックMariaDB
  • カレントリードMariaDB
  • インデックスMariaDB
  • 論理削除(ソフトデリート)MariaDB
  • awk(オーク)の使い方についてLinux
  • NOT NULL 制約と NULL を許容した時の動作MariaDB
  • 外部キー制約MariaDB
  • MySQL と MariaDB の関係MariaDB
  • Docker で PostgreSQL のコンテナの使用Linux

アーカイブ

  • 2026/01
  • 2025/12
  • 2025/11
  • 2025/10
  • 2025/09
  • 2025/08
  • /00

以前のカテゴリー一覧

  • CakePHP3
  • CentOS7
  • HTML・CSS・JavaScript
  • Haskell
  • JavaScript
  • Kotlin
  • Laravel5
  • PHP
  • Python
  • Ruby
  • RubyOnRails5
  • TypeScript
  • Vue.js
  • Webサーバ講座
  • Webプログラミング講座
  • jQuery
  • linux
  • パソコン講座
  • ブログ
  • プログラミング講座
  • メモ帳作成講座
  • 数学

Copyright © 9cubed. All Rights Reserved.

プライバシーポリシー 利用規約
▲