Heim php教程 php手册 Vier Isolationsstufen von MySQL-Transaktionen

Vier Isolationsstufen von MySQL-Transaktionen

Aug 04, 2016 am 08:56 AM

Wir werden Transaktionen in der Entwicklungsarbeit verwenden. Wissen Sie also, welche Arten von Transaktionen es gibt?
Der MYSQL-Standard definiert vier Arten von Isolationsstufen, die dazu dienen, einzuschränken, welche Änderungen innerhalb und außerhalb der Transaktion sichtbar und welche unsichtbar sind.
Niedrigere Isolationsstufen unterstützen im Allgemeinen eine höhere Parallelität und haben einen geringeren Systemaufwand.
Isolationsstufen von niedrig nach hoch: Nicht festgeschrieben lesen < Wiederholbar lesen <
Uncommitted lesen

Auf dieser Isolationsstufe können alle Transaktionen die Ausführungsergebnisse anderer nicht festgeschriebener Transaktionen sehen.
Diese Isolationsstufe wird in praktischen Anwendungen selten verwendet, da ihre Leistung nicht viel besser ist als die anderer Stufen.
Das Lesen nicht festgeschriebener Daten wird auch als Dirty Read bezeichnet. [窗口A]:<br /> <br /> mysql> set GLOBAL tx_isolation='READ-UNCOMMITTED';<br> Query OK, 0 rows affected (0.00 sec)<br> <br> mysql> quit;<br> Bye<br> <br> [root@vagrant-centos65 ~]# mysql -uroot -pxxxx(重新登录)<br> <br> mysql> SELECT @@tx_isolation;<br> ------------------ <br> | @@tx_isolation   |<br> ------------------ <br> | READ-UNCOMMITTED |<br> ------------------ <br> 1 row in set (0.00 sec)<br> <br> mysql> use test;<br> Database changed<br> mysql> begin;<br> Query OK, 0 rows affected (0.00 sec)<br> <br> mysql> select * from user;<br> ---- ------ <br> | id | name |<br> ---- ------ <br> |  1 | a    |<br> |  2 | b    |<br> ---- ------ <br> 2 rows in set (0.00 sec)<br> <br> [窗口B]:<br> mysql> select @@tx_isolation;<br> ------------------ <br> | @@tx_isolation   |<br> ------------------ <br> | READ-UNCOMMITTED |<br> ------------------ <br> 1 row in set (0.00 sec)<br> <br> mysql> begin;<br> Query OK, 0 rows affected (0.00 sec)<br> <br> mysql> insert into test.user values (3, 'c');<br> Query OK, 1 row affected (0.00 sec)<br> <br> mysql> select * from user;<br> ---- ------ <br> | id | name |<br> ---- ------ <br> |  1 | a    |<br> |  2 | b    |<br> |  3 | c    |<br> ---- ------ <br> 3 rows in set (0.00 sec)<br> <br> //目前为止,窗口B并未commit;<br> <br> [窗口A]:<br> mysql> select * from user ;<br> ---- ------ <br> | id | name |<br> ---- ------ <br> |  1 | a    |<br> |  2 | b    |<br> |  3 | c    |<br> ---- ------ <br> 3 rows in set (0.00 sec)[Fenster A]:<b> </b> mysql> set GLOBAL tx_isolation='READ-UNCOMMITTED';<br> Abfrage OK, 0 Zeilen betroffen (0,00 Sek.)<br> <br> mysql> quit;<br> Tschüss<code class="prettyprint linenums lang-php"> <br> [root@vagrant-centos65 ~]# mysql -uroot -pxxxx (erneut anmelden)<br> <br> mysql> SELECT @@tx_isolation;<br> ---- <br> |. @@tx_isolation |<br> ---- <br> |. READ-UNCOMMITTED |<br> ---- <br> 1 Reihe im Satz (0,00 Sek.)<br> <br> mysql> use test;<br> Datenbank geändert<br> mysql> begin;<br> Abfrage OK, 0 Zeilen betroffen (0,00 Sek.)<br> <br> mysql> select * from user;<br> ---- ------ <br> |. id |. name |<br> ---- ------ <br> |. 1 |. a |<br> |. 2 |. b |<br> ---- ------ <br> 2 Reihen im Satz (0,00 Sek.)<br> <br> [Fenster B]:<br> mysql> select @@tx_isolation;<br> ---- <br> |. @@tx_isolation |<br> ---- <br> |. READ-UNCOMMITTED |<br> ---- <br> 1 Reihe im Satz (0,00 Sek.)<br> <br> mysql> begin;<br> Abfrage OK, 0 Zeilen betroffen (0,00 Sek.)<br> <br> mysql> in test.user-Werte einfügen (3, 'c');<br> Abfrage OK, 1 Zeile betroffen (0,00 Sek.)<br> <br> mysql> select * from user;<br> ---- ------ <br> |. id |. name |<br> ---- ------ <br> |. 1 |. a | |. 2 |. b | |. 3 |. c | ---- ------ 3 Reihen im Satz (0,00 Sek.) //Bisher wurde Fenster B nicht festgeschrieben; [Fenster A]: mysql> select * from user ; ---- ------ |. id |. name | ---- ------ |. 1 |. a | |. 2 |. b | |. 3 |. c | ---- ------ 3 Zeilen im Satz (0,00 Sek.)Read Committed (eingereichten Inhalt lesen) Dies ist die Standardisolationsstufe für die meisten Datenbanksysteme (jedoch nicht die MySQL-Standardeinstellung). Es erfüllt die einfache Definition von Isolation: Eine Transaktion kann nur Änderungen sehen, die von festgeschriebenen Transaktionen vorgenommen wurden. Diese Isolationsstufe unterstützt auch das sogenannte nicht wiederholbare Lesen (NonrepeatableRead), da andere Instanzen derselben Transaktion während der Verarbeitung dieser Instanz möglicherweise neue Commits haben, sodass dieselbe Auswahl möglicherweise unterschiedliche Ergebnisse zurückgibt. [Fenster A]: mysql> SET GLOBAL tx_isolation='READ-COMMITTED'; Abfrage OK, 0 Zeilen betroffen (0,00 Sek.) mysql> quit; Tschüss [root@vagrant-centos65 ~]# mysql -uroot -pxxxx (erneut anmelden) mysql> SELECT @@tx_isolation; ---------------- |. @@tx_isolation | ---------------- |. READ-COMMITTED | ---------------- 1 Reihe im Satz (0,00 Sek.) mysql> begin; Abfrage OK, 0 Zeilen betroffen (0,00 Sek.) mysql> select * from test.user; ---- ------ |. id |. name | ---- ------ |. 1 |. a | |. 2 |. b | ---- ------ 2 Reihen im Satz (0,00 Sek.) [Fenster B]: mysql> SELECT @@tx_isolation; ---------------- |. @@tx_isolation | ---------------- |. READ-COMMITTED | ---------------- 1 Reihe im Satz (0,00 Sek.) mysql> begin; Abfrage OK, 0 Zeilen betroffen (0,00 Sek.) mysql> Wählen Sie * aus test.user;
aus ---- ------
| id | Name |
---- ------
|  1 | a    |
|  2 | b    |
---- ------
2 Zeilen im Satz (0,00 Sek.)

mysql> löschen aus test.user wo id=1;
Abfrage OK, 1 Zeile betroffen (0,00 Sek.)

mysql> Wählen Sie * aus test.user;
aus ---- ------
| id | Name |
---- ------
|  2 | b    |
---- ------
1 Zeile pro Satz (0,00 Sek.)

[窗口A]:

mysql> Wählen Sie * aus test.user;
aus ---- ------
| id | Name |
---- ------
|  1 | a    |
|  2 | b    |
---- ------
2 Zeilen im Satz (0,00 Sek.)

[窗口B]:

mysql> verpflichten;
Abfrage OK, 0 Zeilen betroffen (0,02 Sek.)

[窗口A]:

mysql> Wählen Sie * aus test.user;
aus ---- ------
| id | Name |
---- ------
|  2 | b    |
---- ------
1 Zeile pro Satz (0,00 Sek.)Wiederholbares Lesen(可重读)

这是MySQL的默认事务隔离级别,它确保同一事务的多个实例在并发读取数据时,会看到同样的数据行.
不过理论上,这会导致另一个棘手的问题:幻读 (Phantom Read)。
简单的说, 幻读指当用户读取某一范围的数据行时, 另一个事务又在该范围内插入了新行, 当用户再读取该范围的数据行时,会发现有新的“幻影“ 行.
InnoDB 和 Falcon 存储引擎通过多版本并发控制( MVCC , Multiversion Concurrency Control )机制解决了该问题。 [窗口 A]: <code class="prettyprint linenums lang-php">[窗口A]:<br> <br> mysql> SET GLOBAL tx_isolation='REPEATABLE-READ';<br> Query OK, 0 rows affected (0.00 sec)<br> <br> mysql> quit;<br> Bye<br> <br> [root@vagrant-centos65 ~]# mysql -uroot -pxxxx(重新登录)<br> <br> mysql> SELECT @@tx_isolation;<br> ----------------- <br> | @@tx_isolation  |<br> ----------------- <br> | REPEATABLE-READ |<br> ----------------- <br> 1 row in set (0.00 sec)<br> <br> mysql> begin;<br> Query OK, 0 rows affected (0.00 sec)<br> <br> [窗口B]:<br> <br> mysql> quit;<br> Bye<br> <br> [root@vagrant-centos65 ~]# mysql -uroot -pxxxx(重新登录)<br> <br> mysql> SELECT @@tx_isolation;<br> ----------------- <br> | @@tx_isolation  |<br> ----------------- <br> | REPEATABLE-READ |<br> ----------------- <br> 1 row in set (0.00 sec)<br> <br> mysql> insert into test.user values (4, 'd');<br> Query OK, 1 row affected (0.00 sec)<br> <br> mysql> select * from test.user;<br> ---- ------ <br> | id | name |<br> ---- ------ <br> |  2 | b    |<br> |  4 | d    |<br> ---- ------ <br> 2 rows in set (0.00 sec)<br> <br> [窗口A]:<br> <br> mysql> select * from test.user;<br> ---- ------ <br> | id | name |<br> ---- ------ <br> |  2 | b    |<br> ---- ------ <br> 1 rows in set (0.00 sec)<br> <br> mysql> commit;<br> Query OK, 0 rows affected (0.00 sec)<br> <br> mysql> select * from test.user;<br> ---- ------ <br> | id | name |<br> ---- ------ <br> |  2 | b    |<br> |  4 | d    |<br> ---- ------ <br> 2 rows in set (0.00 sec) mysql> SET GLOBAL tx_isolation='REPEATABLE-READ'; Abfrage OK, 0 Zeilen betroffen (0,00 Sek.)

mysql> aufhören;
Tschüss [root@vagrant-centos65 ~]# mysql -uroot -pxxxx(重新登录) mysql> SELECT @@tx_isolation; ----------------- | @@tx_isolation  | ----------------- | WIEDERHOLBARES LESEN | ----------------- 1 Zeile pro Satz (0,00 Sek.) mysql> beginnen; Abfrage OK, 0 Zeilen betroffen (0,00 Sek.) [窗口B]: mysql> aufhören; Tschüss [root@vagrant-centos65 ~]# mysql -uroot -pxxxx(重新登录) mysql> SELECT @@tx_isolation; ----------------- | @@tx_isolation  | ----------------- | WIEDERHOLBARES LESEN | ----------------- 1 Zeile pro Satz (0,00 Sek.) mysql> insert in test.user values (4, 'd'); Abfrage OK, 1 Zeile betroffen (0,00 Sek.) mysql> Wählen Sie * aus test.user; aus ---- ------ | id | Name | ---- ------ |  2 | b    | |  4 | d    | ---- ------ 2 Zeilen im Satz (0,00 Sek.) [窗口A]: mysql> Wählen Sie * aus test.user; aus ---- ------ | id | Name | ---- ------ |  2 | b    | ---- ------ 1 Zeilen im Satz (0,00 Sek.) mysql> verpflichten; Abfrage OK, 0 Zeilen betroffen (0,00 Sek.) mysql> Wählen Sie * aus test.user; aus ---- ------ | id | Name | ---- ------ |  2 | b    | |  4 | d    | ---- ------ 2 Zeilen im Satz (0,00 Sek.)Serialisierbar(序列化执行) 这是最高的隔离级别,它通过强制事务排序,使之不可能相互冲突,从而解决幻读问题.Kurz gesagt, es fügt jeder gelesenen Datenzeile eine gemeinsame Sperre hinzu. Auf dieser Ebene kann es zu zahlreichen Zeitüberschreitungen und Sperrkonflikten kommen. [窗口A]:<br> <br> mysql> SET GLOBAL tx_isolation='SERIALIZABLE';<br> Query OK, 0 rows affected (0.00 sec)<br> <br> mysql> quit;<br> Bye<br> <br> [root@vagrant-centos65 ~]# mysql -uroot -pxxxx(重新登录)<br> <br> mysql> SELECT @@tx_isolation;<br> ---------------- <br> | @@tx_isolation |<br> ---------------- <br> | SERIALIZABLE   |<br> ---------------- <br> 1 row in set (0.00 sec)<br> <br> mysql> select * from test.user;<br> ---- ------ <br> | id | name |<br> ---- ------ <br> |  2 | b    |<br> |  4 | d    |<br> ---- ------ <br> 2 rows in set (0.00 sec)<br> <br> mysql> begin;<br> Query OK, 0 rows affected (0.00 sec)<br> <br> mysql> insert into test.user values (5, 'e');<br> Query OK, 1 row affected (0.00 sec)<br> <br> [窗口B]:<br> <br> mysql> quit;<br> Bye<br> <br> [root@vagrant-centos65 ~]# mysql -uroot -pxxxx(重新登录)<br> <br> mysql> SELECT @@tx_isolation;<br> ---------------- <br> | @@tx_isolation |<br> ---------------- <br> | SERIALIZABLE   |<br> ---------------- <br> 1 row in set (0.00 sec)<br> <br> mysql> select * from test.user;<br> ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction<br> <br> [窗口A]:<br> <br> mysql> commit;<br> Query OK, 0 rows affected (0.01 sec)<br> <br> [窗口B]:<br> <br> mysql> mysql> select * from test.user;<br> ---- ------ <br> | id | name |<br> ---- ------ <br> |  2 | b    |<br> |  4 | d    |<br> |  5 | e    |<br> ---- ------ <br> 3 rows in set (0.00 sec)Danke ~

Quelle: http://mp.weixin.qq.com/s?__biz=MjM5NDM4MDIwNw==&mid=2448834642&idx=1&sn=c02c5cc8ab0c1f29142ac8f8aa6b78af#rd

Für mehr [trockenen Informationsaustausch] folgen Sie bitte meinem persönlichen Abonnementkonto.
Vier Isolationsstufen von MySQL-Transaktionen

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Erfahren Sie mehr über einführende Codebeispiele für die Python-Programmierung Erfahren Sie mehr über einführende Codebeispiele für die Python-Programmierung Jan 04, 2024 am 10:50 AM

Erfahren Sie anhand einführender Codebeispiele mehr über die Python-Programmierung. Python ist eine leicht zu erlernende und dennoch leistungsstarke Programmiersprache. Für Anfänger ist es sehr wichtig, die einführenden Codebeispiele der Python-Programmierung zu verstehen. In diesem Artikel finden Sie einige konkrete Codebeispiele, die Ihnen den schnellen Einstieg erleichtern. Print HelloWorldprint("HelloWorld") Dies ist das einfachste Codebeispiel in Python. Mit der Funktion print() wird der angegebene Inhalt ausgegeben

PHP-Variablen in Aktion: 10 Anwendungsbeispiele aus der Praxis PHP-Variablen in Aktion: 10 Anwendungsbeispiele aus der Praxis Feb 19, 2024 pm 03:00 PM

PHP-Variablen speichern Werte während der Programmlaufzeit und sind für den Aufbau dynamischer und interaktiver WEB-Anwendungen von entscheidender Bedeutung. Dieser Artikel wirft einen detaillierten Blick auf PHP-Variablen und zeigt sie anhand von 10 Beispielen aus der Praxis. 1. Benutzereingaben speichern $username=$_POST["username"];$passWord=$_POST["password"]; Dieses Beispiel extrahiert den Benutzernamen und das Passwort aus der Formularübermittlung und speichert sie zur weiteren Verarbeitung in Variablen. 2. Legen Sie den Konfigurationswert $database_host="localhost";$database_username="username";$database_pa fest

Beispiele für Go-Sprachprogrammierung: Codebeispiele in der Webentwicklung Beispiele für Go-Sprachprogrammierung: Codebeispiele in der Webentwicklung Mar 04, 2024 pm 04:54 PM

„Beispiele zur Go-Sprachprogrammierung: Codebeispiele in der Webentwicklung“ Mit der rasanten Entwicklung des Internets ist die Webentwicklung zu einem unverzichtbaren Bestandteil verschiedener Branchen geworden. Als Programmiersprache mit leistungsstarken Funktionen und überlegener Leistung wird die Go-Sprache von Entwicklern in der Webentwicklung zunehmend bevorzugt. In diesem Artikel wird anhand spezifischer Codebeispiele erläutert, wie die Go-Sprache für die Webentwicklung verwendet wird, damit die Leser die Go-Sprache besser verstehen und zum Erstellen ihrer eigenen Webanwendungen verwenden können. 1. Einfacher HTTP-Server Beginnen wir zunächst mit a

Java implementiert einen einfachen Blasensortierungscode Java implementiert einen einfachen Blasensortierungscode Jan 30, 2024 am 09:34 AM

Das einfachste Codebeispiel für die Blasensortierung in Java ist ein allgemeiner Sortieralgorithmus. Seine Grundidee besteht darin, die zu sortierende Reihenfolge durch Vergleich und Austausch benachbarter Elemente schrittweise anzupassen. Hier ist ein einfaches Java-Codebeispiel, das zeigt, wie die Blasensortierung implementiert wird: publicclassBubbleSort{publicstaticvoidbubbleSort(int[]arr){int

Vom Anfänger bis zum Experten: Code-Implementierung häufig verwendeter Datenstrukturen in der Go-Sprache Vom Anfänger bis zum Experten: Code-Implementierung häufig verwendeter Datenstrukturen in der Go-Sprache Mar 04, 2024 pm 03:09 PM

Titel: Vom Anfänger zur Meisterschaft: Code-Implementierung häufig verwendeter Datenstrukturen in der Go-Sprache. Datenstrukturen spielen eine wichtige Rolle in der Programmierung und sind die Grundlage der Programmierung. In der Go-Sprache gibt es viele häufig verwendete Datenstrukturen, und die Beherrschung der Implementierung dieser Datenstrukturen ist entscheidend, um ein guter Programmierer zu werden. In diesem Artikel werden die häufig verwendeten Datenstrukturen in der Go-Sprache vorgestellt und entsprechende Codebeispiele gegeben, um den Lesern den Einstieg bis zur Beherrschung dieser Datenstrukturen zu erleichtern. 1. Array Array ist eine grundlegende Datenstruktur, bei der es sich um eine Gruppe desselben Typs handelt.

Huawei Cloud Edge Computing Interconnection Guide: Java-Codebeispiele zur schnellen Implementierung von Schnittstellen Huawei Cloud Edge Computing Interconnection Guide: Java-Codebeispiele zur schnellen Implementierung von Schnittstellen Jul 05, 2023 pm 09:57 PM

Huawei Cloud Edge Computing Interconnection Guide: Java-Codebeispiele zur schnellen Implementierung von Schnittstellen Mit der rasanten Entwicklung der IoT-Technologie und dem Aufstieg des Edge Computing beginnen immer mehr Unternehmen, der Anwendung von Edge Computing Aufmerksamkeit zu schenken. Huawei Cloud bietet Edge-Computing-Dienste und stellt Unternehmen äußerst zuverlässige Computerressourcen und eine praktische Entwicklungsumgebung zur Verfügung, wodurch Edge-Computing-Anwendungen einfacher zu implementieren sind. In diesem Artikel erfahren Sie, wie Sie die Huawei Cloud Edge Computing-Schnittstelle schnell über Java-Code implementieren. Zuerst müssen wir die Entwicklungsumgebung vorbereiten. Stellen Sie sicher, dass Sie das Java Development Kit installiert haben (

So schreiben Sie mit PHP Funktionscode für die Bestandsverwaltung im Bestandsverwaltungssystem So schreiben Sie mit PHP Funktionscode für die Bestandsverwaltung im Bestandsverwaltungssystem Aug 06, 2023 pm 04:49 PM

So schreiben Sie mit PHP den Funktionscode für die Bestandsverwaltung im Bestandsverwaltungssystem. Die Bestandsverwaltung ist für viele Unternehmen ein unverzichtbarer Bestandteil. Für Unternehmen mit mehreren Lagern ist die Bestandsverwaltungsfunktion besonders wichtig. Durch die ordnungsgemäße Verwaltung und Nachverfolgung des Lagerbestands können Unternehmen den Lagerbestand auf verschiedene Lager verteilen, die Betriebskosten optimieren und die Effizienz der Zusammenarbeit verbessern. In diesem Artikel erfahren Sie, wie Sie mit PHP Code für Lagerverwaltungsfunktionen schreiben und erhalten relevante Codebeispiele. 1. Richten Sie die Datenbank ein, bevor Sie mit dem Schreiben des Codes für die Lagerverwaltungsfunktion beginnen.

Anleitung und Beispiele: Erfahren Sie, wie Sie den Auswahlsortierungsalgorithmus in Java implementieren Anleitung und Beispiele: Erfahren Sie, wie Sie den Auswahlsortierungsalgorithmus in Java implementieren Feb 18, 2024 am 10:52 AM

Code-Schreibanleitung und Beispiele für die Java-Auswahlsortierung Die Auswahlsortierung ist ein einfacher und intuitiver Sortieralgorithmus. Die Idee besteht darin, jedes Mal das kleinste (oder größte) Element aus den unsortierten Elementen auszuwählen und es auszutauschen, bis alle Elemente sortiert sind. Dieser Artikel enthält eine Anleitung zum Schreiben von Code für die Auswahlsortierung und fügt spezifischen Java-Beispielcode hinzu. Algorithmusprinzip Das Grundprinzip der Auswahlsortierung besteht darin, das zu sortierende Array in zwei Teile zu unterteilen: sortiert und unsortiert. Dabei wird jeweils das kleinste (oder größte) Element aus dem unsortierten Teil ausgewählt und am Ende des sortierten Teils platziert. Wiederholen Sie das oben Gesagte

See all articles