バージョンチェーン InnoDB エンジン テーブルでは、クラスター化インデックス レコードに 2 つの非表示の列があります。
たとえば、trx_id 60 のトランザクションがあり、次のステートメントを実行しているとします: update table set name = 'Xiaoming1' where id = 1 この時点で、UNDOログにバージョンチェーンが存在する。
バージョンチェーンはgitに似ており、データ行のバージョン管理を実行し、undo_logを通じてロールバックすることができます。 閲覧ビュー Read Committed と Repeatable Read の違いは、ReadView を生成するための戦略が異なることです。 ReadView には主に、システム内で現在アクティブな読み取りおよび書き込みトランザクション (コミットされていない開始トランザクション) を保存するためのリストがあります。このリストは、レコードのバージョンが現在のトランザクションに表示されるかどうかを判断するために使用されます。現在のリスト内のトランザクションIDが[80,100]であると仮定します。 id <= 80 (最小トランザクション ID) id >= 80 && id <= 100 id >= 100 これらのレコードはバージョン チェーンで検索されます。最初に最新のレコードが検索されます。最新のレコードのトランザクション ID が条件を満たさず、表示されていない場合は、以前のバージョンが検索され、現在のトランザクションの ID がこのバージョンのトランザクション ID と比較され、アクセスできるかどうかが確認されます。このプロセスは、表示可能なバージョンが返されるか、プロセスが終了するまで繰り返されます。 たとえば、Read Committed 分離レベルでは次のようになります。 たとえば、この時点でトランザクション ID 100 のトランザクションがあり、名前が Xiaoming 2 になるように名前が変更されますが、トランザクションはまだコミットされていません。現時点でのバージョンチェーンは
このとき、別のトランザクションがID 1のレコードを照会するSELECTステートメントを開始し、生成されたReadViewリストは[100]のみになります。次に、バージョン チェーンに移動して検索します。まず、最新のものを見つける必要があります。trx_id が 100 であることがわかります。これは、Xiaoming 2 という名前のレコードです。これはリスト内にあるため、アクセスできません。 このとき、ポインターを介してXiaoming 1という名前の次のレコードを探し続け、trx_idが60であることがわかりました。これはリスト内の最小IDより小さいため、アクセスできます。直接アクセスの結果はXiaoming 1です。 このとき、トランザクション ID 100 のトランザクションをコミットし、ID 110 の新しいトランザクションを作成して ID 1 のレコードを変更し、トランザクションはコミットしません。 --trx_id = 110 始める; テーブルセット名 = 'Xiaoming3'、ID = 1 を更新します。 現時点では、バージョンチェーンは
この時点で、前の選択トランザクションは、ID 1 のレコードを照会するために別のクエリを実行しました。 分離レベルが異なると結果も異なります コミット読み取り分離レベルの場合は、この時点で新しい ReadView が作成され、アクティブ トランザクション リストの値が [110] に変更されます。 上記のステートメントによれば、バージョン チェーンに移動して trx_id を比較し、適切な結果 (Xiao Ming 2) を見つけます。 繰り返し読み取り分離レベルの場合、ReadView は最初の選択時に生成された ReadView のままです。つまり、リストの値は [100] のままです。したがって、選択の結果は Xiao Ming 1 になります。したがって、2 番目の選択の結果は最初の選択と同じなので、繰り返し読み取りと呼ばれます。 これは MySQL の MVCC であり、バージョン チェーンを通じて複数のバージョンを実装し、読み取り書き込み操作と書き込み読み取り操作を同時に実行できます。さまざまな ReadView 生成戦略を通じて、さまざまな分離レベルが実現されます。 上記は、MySQL - MVCC の詳細についての簡単な分析です。MySQL mvcc の詳細については、123WORDPRESS.COM の他の関連記事に注目してください。 以下もご興味があるかもしれません:
|
<<: WindowsにOpenSSLをインストールし、OpenSSLを使用して公開鍵と秘密鍵を生成します。
序文比較的複雑な大規模システムでは、複雑なロジックで処理する必要があるオブジェクトまたはデータ フロ...
目次典型的なウォーターフォールウェブサイトウォーターフォールフローレイアウトの原則一般的な考え方具体...
King of Glory をプレイしたことがある人なら、このページの効果をよくご存知でしょう。なぜ...
MySQL ドキュメントでは、MySQL 変数はシステム変数とユーザー変数の 2 つのカテゴリに分類...
目次Vue2.x の使用法グローバル登録部分登録使用フック機能フック関数のパラメータVue3.x の...
概要: nginx リバース プロキシ jira を構成し、https を実装します。Tomcat ...
目次概要ハッシュプロパティホストプロパティホスト名属性Href属性起源のプロパティユーザー名とパスワ...
多くの場合、移行は避けられません。ハードウェアのアップグレード、データ センターの変更、古いオペレー...
この記事では、カスタムツリーコンポーネントを再帰的に実装するVueの具体的なコードを参考までに共有し...
序文セキュリティ部門からSQLインジェクションやXSS攻撃の脆弱性などに関する警告メールを頻繁に受け...
Windows サーバー リモート デスクトップのデフォルトのポート番号は 3389 です。職場でサ...
LEMP(Linux + Nginx + MySQL + PHP)は、基本的に今日のWeb開発者にと...
参考までに、JavaScriptを使用してドロップダウンメニューを実装します。具体的な内容は次のとお...
この記事の例では、Vueドロップダウンメニューのコンポーネント開発の具体的なコードを参考までに共有し...
今日の画面解像度は、320 ピクセル (iPhone) ほど小さいものから、2560 ピクセル以上 ...