開発作業ではトランザクションを利用することになりますが、トランザクションにはどのような種類があるかご存知ですか?
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
もっと[辛口な情報共有]をしたい場合は、私の個人購読アカウントをフォローしてください。