トランザクション分離レベルの設定 グローバルトランザクション分離レベルを読み取りコミット済みに設定; //グローバルセッショントランザクション分離レベルを読み取りコミット済みに設定; //現在のセッション トランザクションの送信方法を変更する(自動的に送信するかどうか、MySQL はデフォルトで自動的に送信します) SET AUTOCOMMIT = 1; // 自動的にコミット、0 手動でコミット 異なるデータベース エンジンには異なる MVCC モードがあり、通常は楽観的同時実行制御と悲観的同時実行制御です。 インノDB 例: InnoDB の MVCC は、レコードの各行の後に 2 つの隠し列を保存することによって実装されます。これら 2 つの列の 1 つは行の作成時刻を格納し、もう 1 つは行の有効期限 (または削除時刻) を格納します。もちろん、保存されるのは実際の時間値ではなく、システムのバージョン番号です。新しいトランザクションが開始されるたびに、システムのバージョン番号は自動的に増加します。トランザクション開始時のシステムバージョン番号は、照会されたバージョン番号と比較するためのトランザクションバージョン番号として使用されます。 選択 InnoDB は各行を次の 2 つの条件と照合します。 a. InnoDB は、現在のトランザクション バージョンよりも前のバージョンのデータ行のみを検索します (つまり、行のシステム バージョン番号がトランザクションのシステム バージョン番号以下です)。これにより、トランザクションによって読み取られる行は、トランザクションの開始前に存在していたか、トランザクション自体によって挿入または変更されたことが保証されます。 b. 削除された行のバージョンは未定義であるか、現在のトランザクション バージョン番号より大きいです。これにより、トランザクションによって読み取られた行が、トランザクションの開始前に削除されていないことが保証されます。 上記の 2 つの条件を満たすレコードのみがクエリ結果として返されます。 入れる InnoDB は、新しく挿入された各行の行バージョン番号として現在のシステム バージョン番号を保存します。 消去 InnoDB は、削除された各行の行削除識別子として現在のシステム バージョン番号を保存します。 アップデート InnoDB は、新しい行を挿入するときに現在のシステム バージョン番号を行バージョン番号として保存し、行削除マーカーとして元の行に現在のシステム バージョン番号を保存します。 知らせ: MVCC は、REPEATABLE READ および READ COMMITED 分離レベルでのみ機能します。他の 2 つの分離レベルは MVCC と互換性がありません。READ UNCOMITTED では、現在のトランザクション バージョンに準拠するデータ行ではなく、常に最新のデータ行が読み取られるためです。 SERIALIZABLE はすべての読み取り行をロックします。 テーブルの状態を確認する 'task' のようなテーブル ステータスを表示します\G; ダーティリード、非反復リード、ファントムリード ダーティ リード: 現在のトランザクションは別のトランザクションのコミットされていない状態を読み取りますが、トランザクションは分離されていません。 反復不可能な読み取り: トランザクションの分離は達成されますが、同じデータが 2 回読み取られるとデータの不整合が見つかります。 ファントム リード: 同じデータ バッチを 2 回クエリすると、新しいデータが挿入されたことがわかります。これは主に、他のトランザクションがデータ セットの途中でデータを挿入したためです。 (ギャップロックを追加するとこの問題は解決します) 以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。 以下もご興味があるかもしれません:
|
<<: MySQLにおける分散ロックの考え方をDBの助けを借りて詳しく説明します
背景何が起こったかというと、Luzhu は偶然、宇宙で最高の外部スピーカーを備えた携帯電話について知...
最新のソリューション: -v /usr/share/zoneinfo/Asia/Shanghai:/...
半年もブログを書いていなかったので、少し恥ずかしいです... 正月休みは、Dota をプレイしたり ...
これらの仕様は、下位互換性のあるドキュメントを Web 上で公開し、できるだけ幅広いユーザーがアクセ...
<br />この記事は主に、初心者にXHTMLの基本知識と、XHTMLとHTMLの違いを...
序文この記事では、div の幅を 100% に設定し、親要素を超えてパディングまたはマージンを設定す...
いろいろ苦労しましたが、やっと yum インストールの手順がわかりました。以前、バイナリ パッケージ...
CSS を使用して要素の円弧の動きを制御する方法CSS3 の新しい属性 transfrom トランジ...
目次1. 概要2. nginx.conf 1) 設定ファイルの場所2) ワーカープロセス3) イベン...
さっそく、コードを直接投稿します。具体的なコードは次のとおりです。 <!DOCTYPE htm...
スタイル シートは、ドキュメントの表示方法、発音方法、または入力方法を記述します。スタイル シートは...
序文個人の実際の開発で使用した効果問題を、今後の開発やレビューに役立てるためにまとめています。他の人...
ユーザーから情報を収集する場合、Web フォームを使用するより簡単で直接的な方法はありません。適切に...
1. W3C バージョンの flex 2009年版フラグ: display: box; または bo...
以前、私は自分で WordPress を構築していましたが、当時はサードパーティの仮想ホストを使用し...