Mysql トランザクションの 4 つの分離レベル
開発作業ではトランザクションを利用することになりますが、トランザクションにはどのような種類があるかご存知ですか?
MYSQL 標準では 4 種類の分離レベルが定義されており、トランザクション内外のどの変更が表示され、どの変更が不可視であるかを制限するために使用されます。
一般に、分離レベルが低いほど高い同時実行性がサポートされ、システムのオーバーヘッドが低くなります。
分離レベルは低から高まで: 非コミット読み取り Read Uncommitted (コミットされていないコンテンツを読む)
この分離レベルでは、すべてのトランザクションが他のコミットされていないトランザクションの実行結果を確認できます。
この分離レベルは他のレベルと比べてパフォーマンスがそれほど優れていないため、実際のアプリケーションではほとんど使用されません。
コミットされていないデータの読み取りは、ダーティ リードとも呼ばれます。 [ウィンドウA]:<br>
<br>
mysql> set GLOBAL tx_isolation='READ-UNCOMMITTED';<br>
クエリ OK、影響を受ける行は 0 (0.00 秒)<br>
<br>
mysql> 終了;<br>
さようなら<br>
<br>
[root@vagrant-centos65 ~]# mysql -uroot -pxxxx (再度ログイン)<br>
<br>
mysql> SELECT @@tx_isolation;<br>
+-----------------+<br>
| @@tx_isolation |<br>
+-----------------+<br>
| 読み取り未コミット |<br>
+-----------------+<br>
セット内の 1 行 (0.00 秒)<br>
<br>
mysql> テストを使用します;<br>
データベースが変更されました<br>
mysql> を開始します;<br>
クエリ OK、影響を受ける行は 0 (0.00 秒)<br>
<br>
mysql> ユーザーから * を選択;<br>
+-----+-----+<br>
| ID |<br>
+-----+-----+<br>
| 1 |<br>
| 2 |<br>
+-----+-----+<br>
2 行セット (0.00 秒)<br>
<br>
[ウィンドウB]:<br>
mysql> @@tx_isolation; を選択します。
+-----------------+<br>
| @@tx_isolation |<br>
+-----------------+<br>
| 読み取り未コミット |<br>
+-----------------+<br>
セット内の 1 行 (0.00 秒)<br>
<br>
mysql> を開始します;<br>
クエリ OK、影響を受ける行は 0 (0.00 秒)<br>
<br>
mysql> test.user 値に挿入 (3, 'c');<br>
クエリは OK、1 行が影響を受けました (0.00 秒)<br>
<br>
mysql> ユーザーから * を選択;<br>
+-----+-----+<br>
| ID |<br>
+-----+-----+<br>
| 1 |<br>
| 2 |<br>
| 3 |<br>
+-----+-----+<br>
3 行セット (0.00 秒)<br>
<br>
//これまでのところ、ウィンドウ B はコミットされていません;<br>
<br>
[窓A]:<br>
mysql> ユーザーから * を選択 ;<br>
+-----+-----+<br>
| ID |<br>
+-----+-----+<br>
| 1 |<br>
| 2 |<br>
| 3 |<br>
+-----+-----+<br>
セット内の 3 行 (0.00 秒)<br>
コミットされた読み取り (送信されたコンテンツの読み取り)
これは、ほとんどのデータベース システムのデフォルトの分離レベルです (ただし、MySQL のデフォルトではありません)。
これは分離の単純な定義を満たしています。つまり、トランザクションはコミットされたトランザクションによって行われた変更のみを確認できます。
この分離レベルは、いわゆる非反復読み取り (NonrepeatableRead) もサポートしています。これは、同じトランザクションの他のインスタンスがこのインスタンスの処理中に新しいコミットを持つ可能性があるため、同じ選択が異なる結果を返す可能性があるためです。
[ウィンドウA]:
<br>
mysql> SET GLOBAL tx_isolation='READ-COMMITTED';<br>
クエリ OK、影響を受ける行は 0 (0.00 秒)<br>
<br>
mysql> 終了;<br>
さようなら<br>
<br>
[root@vagrant-centos65 ~]# mysql -uroot -pxxxx (再度ログイン)<br>
<br>
mysql> SELECT @@tx_isolation;<br>
+----------------+<br>
| @@tx_isolation |<br>
+----------------+<br>
| 読み取りコミット済み |<br>
+----------------+<br>
セット内の 1 行 (0.00 秒)<br>
<br>
mysql> を開始します;<br>
クエリ OK、影響を受ける行は 0 (0.00 秒)<br>
<br>
mysql> select * from test.user;<br>
+-----+-----+<br>
| ID |<br>
+-----+-----+<br>
| 1 |<br>
| 2 |<br>
+-----+-----+<br>
2 行セット (0.00 秒)<br>
<br>
<br>
[ウィンドウB]:<br>
<br>
mysql> SELECT @@tx_isolation;<br>
+----------------+<br>
| @@tx_isolation |<br>
+----------------+<br>
| 読み取りコミット済み |<br>
+----------------+<br>
セット内の 1 行 (0.00 秒)<br>
<br>
mysql> を開始します;<br>
クエリ OK、影響を受ける行は 0 (0.00 秒)<br>
<br>mysql> select * from test.user;<br>
+-----+-----+<br>
| ID | 名前 |<br>
+-----+-----+<br>
| 1 | a |<br>
| 2 | b |<br>
+-----+-----+<br>
セット内の 2 行 (0.00 秒)<br>
<br>
mysql> test.userから削除(id=1;<br>)
クエリは OK、1 行が影響を受けました (0.00 秒)<br>
<br>
mysql> select * from test.user;<br>
+-----+-----+<br>
| ID | 名前 |<br>
+-----+-----+<br>
| 2 | b |<br>
+-----+-----+<br>
セット内の 1 行 (0.00 秒)<br>
<br>
[窗口A]:<br>
<br>
mysql> select * from test.user;<br>
+-----+-----+<br>
| ID | 名前 |<br>
+-----+-----+<br>
| 1 | a |<br>
| 2 | b |<br>
+-----+-----+<br>
セット内の 2 行 (0.00 秒)<br>
<br>
[窗口B]:<br>
<br>
mysql> コミット;<br>
クエリは OK、影響を受ける行は 0 行あります (0.02 秒)<br>
<br>
[窗口A]:<br>
<br>
mysql> select * from test.user;<br>
+-----+-----+<br>
| ID | 名前 |<br>
+-----+-----+<br>
| 2 | b |<br>
+-----+-----+<br>
セット内の 1 行 (0.00 秒)
Repeatable Read(可重读)
これは MySQL の承認ジョブ分離レベルであり、同じジョブの多くの例がデータの取得と送信時に同じように見えることを保証します。
処理を行わないと、別の棘ハンドの問題:幻覚(ファントムリード)が発生する可能性があります。
幻覚は、ユーザーが特定の範囲のデータを取得するときに、別の事がその範囲内に新しい行を挿入し、ユーザーがその範囲のデータを再取得すると、新しいものが発行されることを意味します。幻影』行。
InnoDB と Falcon は、複数のバージョンを介して転送および発行制御 (MVCC、Multiversion Concurrency Control) 機構によってこの問題を解決しています。
mysql> SET GLOBAL tx_isolation='REPEATABLE-READ';
クエリは OK、影響を受ける行は 0 行あります (0.00 秒)
mysql> やめてください;<br>
さようなら<br>
<br>
[root@vagrant-centos65 ~]# mysql -uroot -pxxxx(重新登录)<br>
<br>
mysql> SELECT @@tx_isolation;<br>
+-----------------+<br>
| @@tx_isolation |<br>
+-----------------+<br>
| 繰り返し読める |<br>
+-----------------+<br>
セット内の 1 行 (0.00 秒)<br>
<br>
mysql> 始めます;<br>
クエリは OK、影響を受ける行は 0 行あります (0.00 秒)<br>
<br>
[窗口B]:<br>
<br>
mysql> やめてください;<br>
さようなら<br>
<br>
[root@vagrant-centos65 ~]# mysql -uroot -pxxxx(重新登录)<br>
<br>
mysql> SELECT @@tx_isolation;<br>
+-----------------+<br>
| @@tx_isolation |<br>
+-----------------+<br>
| 繰り返し読める |<br>
+-----------------+<br>
セット内の 1 行 (0.00 秒)<br>
<br>
mysql> insert in test.user value (4, 'd');<br>
クエリは OK、1 行が影響を受けました (0.00 秒)<br>
<br>
mysql> select * from test.user;<br>
+-----+-----+<br>
| ID | 名前 |<br>
+-----+-----+<br>
| 2 | b |<br>
| 4 | d |<br>
+-----+-----+<br>
セット内の 2 行 (0.00 秒)<br>
<br>
[窗口A]:<br>
<br>
mysql> select * from test.user;<br>
+-----+-----+<br>
| ID | 名前 |<br>
+-----+-----+<br>
| 2 | b |<br>
+-----+-----+<br>
セット内の 1 行 (0.00 秒)<br>
<br>
mysql> コミット;<br>
クエリは OK、影響を受ける行は 0 行あります (0.00 秒)<br>
<br>
mysql> select * from test.user;<br>
+-----+-----+<br>
| ID | 名前 |<br>
+-----+-----+<br>
| 2 | b |<br>
| 4 | d |<br>
+-----+-----+<br>
セット内の 2 行 (0.00 秒)<br><br>シリアル化可能(配列化执行)<br><br>
<br>
これは最高の隔離レベルであり、物事の順序を調整することで相互の衝突を可能にし、幻覚の問題を解決します。つまり、読み取られた各データ行に共有ロックが追加されます。このレベルでは、多数のタイムアウトやロック競合が発生する可能性があります。 <code class="prettyprint linenums lang-php">[ウィンドウA]:<br>
<br>
mysql> SET GLOBAL tx_isolation='SERIALIZABLE';<br>
クエリ OK、影響を受ける行は 0 (0.00 秒)<br>
<br>
mysql> 終了;<br>
さようなら<br>
<br>
[root@vagrant-centos65 ~]# mysql -uroot -pxxxx (再度ログイン)<br>
<br>
mysql> SELECT @@tx_isolation;<br>
+----------------+<br>
| @@tx_isolation |<br>
+----------------+<br>
| シリアル化可能 |<br>
+----------------+<br>
セット内の 1 行 (0.00 秒)<br>
<br>
mysql> select * from test.user;<br>
+-----+-----+<br>
| ID |<br>
+-----+-----+<br>
| 2 |<br>
| 4 |<br>
+-----+-----+<br>
2 行セット (0.00 秒)<br>
<br>
mysql> を開始します;<br>
クエリ OK、影響を受ける行は 0 (0.00 秒)<br>
<br>
mysql> test.user 値に挿入 (5, 'e');<br>
クエリは OK、1 行が影響を受けました (0.00 秒)<br>
<br>
[ウィンドウB]:<br>
<br>
mysql> 終了;<br>
さようなら<br>
<br>
[root@vagrant-centos65 ~]# mysql -uroot -pxxxx (再度ログイン)<br>
<br>
mysql> SELECT @@tx_isolation;<br>
+----------------+<br>
| @@tx_isolation |<br>
+----------------+<br>
| シリアル化可能 |<br>
+----------------+<br>
セット内の 1 行 (0.00 秒)<br>
<br>
mysql> select * from test.user;<br>
エラー 1205 (HY000): ロック待機タイムアウトを超過しました。トランザクションを再起動してください。
<br>
[窓A]:<br>
<br>
mysql> コミット;<br>
クエリ OK、影響を受ける行は 0 (0.01 秒)<br>
<br>
[ウィンドウB]:<br>
<br>
mysql> mysql> select * from test.user;<br>
+-----+-----+<br>
| ID |<br>
+-----+-----+<br>
| 2 |<br>
| 4 |<br>
| 5 |<br>
+-----+-----+<br>
3 行セット (0.00 秒)<br>ありがとう ~
出典: http://mp.weixin.qq.com/s?__biz=MjM5NDM4MDIwNw==&mid=2448834642&idx=1&sn=c02c5cc8ab0c1f29142ac8f8aa6b78af#rd
もっと[辛口な情報共有]をしたい場合は、私の個人購読アカウントをフォローしてください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











入門コード例で Python プログラミングについて学ぶ Python は、習得が簡単でありながら強力なプログラミング言語です。初心者にとって、Python プログラミングの入門コード例を理解することは非常に重要です。この記事では、すぐに始めるのに役立つ具体的なコード例をいくつか紹介します。 Print HelloWorldprint("HelloWorld") これは、Python の最も単純なコード例です。 print()関数は、指定された内容を出力するために使用されます。

PHP 変数はプログラムの実行中に値を保存し、動的でインタラクティブな WEB アプリケーションを構築するために重要です。この記事では、PHP 変数を詳しく説明し、10 個の実際の例を使用して実際に動作する様子を示します。 1. ユーザー入力の保存 $username=$_POST["username"];$passWord=$_POST["password"]; この例では、フォーム送信からユーザー名とパスワードを抽出し、その後の処理のために変数に保存します。 2. 構成値 $database_host="localhost";$database_username="username";$database_pa を設定します。

「Go 言語プログラミングの例: Web 開発におけるコード例」 インターネットの急速な発展に伴い、Web 開発はさまざまな業界で不可欠な部分になりました。 Go 言語は、強力な機能と優れたパフォーマンスを備えたプログラミング言語として、Web 開発の開発者にますます好まれています。この記事では、読者が Go 言語をより深く理解し、Go 言語を使用して独自の Web アプリケーションを構築できるように、具体的なコード例を通じて Web 開発に Go 言語を使用する方法を紹介します。 1. シンプルな HTTP サーバー まず、

Java バブル ソートの最も簡単なコード例 バブル ソートは一般的な並べ替えアルゴリズムであり、その基本的な考え方は、並べ替える順序を、隣接する要素の比較と交換を通じて順序付けされた順序に徐々に調整することです。次に、バブル ソートの実装方法を示す簡単な Java コード例を示します。 publicclassBubbleSort{publicstaticvoidbubbleSort(int[]arr){int

タイトル: 初心者から熟練者まで: Go 言語で一般的に使用されるデータ構造のコード実装 データ構造はプログラミングにおいて重要な役割を果たし、プログラミングの基礎です。 Go 言語には、一般的に使用されるデータ構造が多数あり、これらのデータ構造の実装をマスターすることは、優れたプログラマーになるために重要です。この記事では、Go 言語で一般的に使用されるデータ構造を紹介し、読者がこれらのデータ構造を使い始めて習熟するのに役立つ、対応するコード例を示します。 1. 配列 配列は基本的なデータ構造であり、同じ型のグループです。

Huawei クラウド エッジ コンピューティング相互接続ガイド: インターフェイスを迅速に実装するための Java コード サンプル IoT テクノロジーの急速な発展とエッジ コンピューティングの台頭により、ますます多くの企業がエッジ コンピューティングのアプリケーションに注目し始めています。 Huawei Cloud はエッジ コンピューティング サービスを提供し、企業に信頼性の高いコンピューティング リソースと便利な開発環境を提供し、エッジ コンピューティング アプリケーションの実装を容易にします。この記事では、Java コードを通じて Huawei Cloud エッジ コンピューティング インターフェイスを迅速に実装する方法を紹介します。まずは開発環境を準備する必要があります。 Java Development Kit がインストールされていることを確認してください (

PHP を使用して在庫管理システムの在庫管理機能コードを記述する方法 在庫管理は多くの企業にとって不可欠な部分です。複数の倉庫を持つ企業にとって、在庫管理機能は特に重要です。在庫を適切に管理および追跡することで、企業は異なる倉庫間で在庫を割り当て、運用コストを最適化し、コラボレーション効率を向上させることができます。この記事では、PHP を使用して在庫倉庫管理機能のコードを記述する方法を紹介し、関連するコード例を示します。 1. 在庫倉庫管理機能のコードを書き始める前に、データベースを確立します。

Java 選択ソート方法のコード記述ガイドと例 選択ソートは、シンプルで直観的なソート アルゴリズムです。そのアイデアは、ソートされていない要素から毎回最小 (または最大) の要素を選択し、すべての要素がソートされるまで交換することです。この記事では、選択項目の並べ替えのためのコード作成ガイドを提供し、特定の Java サンプル コードを添付します。アルゴリズム原理 選択ソートの基本原理は、ソート対象の配列をソート済み部分とソートされていない部分の 2 つの部分に分割し、その都度、未ソート部分から最小 (または最大) の要素が選択され、ソート済み部分の最後に配置されます。上記を繰り返します
