


Beispiele zur Erläuterung von Shared Locks und Exclusive Locks unter MySQL und InnoDB
Dieser Artikel vermittelt Ihnen relevantes Wissen über gemeinsame Sperren und exklusive Sperren in MySQL. Ich hoffe, dass er für alle hilfreich ist.
Shared Lock
Shared Lock, S Lock, Read Lock sind alle seine Namen.
Und ich nenne ihn gerne Shared Read Lock.
Eine gemeinsame (S) Sperre ermöglicht das Lesen der Transaktion, die die Sperre hält.
Eine gemeinsame Sperre ermöglicht das Lesen der Transaktion, die die Sperre hält.
Das Teilen hier ist Lesen Teilen .
Mit anderen Worten, egal ob auf Zeilen- oder Tabellenebene: Wenn für bestimmte Daten eine gemeinsame Lesesperre festgelegt wird, Andere Transaktionen können weiterhin lesen (dh sie dürfen gemeinsame Lesesperren halten), aber sie kann nicht schreiben, also lesen. Schreiben, gegenseitiger Ausschluss .
Lassen Sie mich übrigens vorstellen, wie Sie eine gemeinsame Sperre (gemeinsame Lesesperre) hinzufügen:
Gemeinsame Sperre auf Tabellenebene, dh gemeinsame Lesesperre auf Tabellenebene:
select * from table(表) lock in share mode ;
Gemeinsame Sperre auf Upstream-Ebene ist eine gemeinsame Lesesperre auf Zeilenebene:
select * from table(表)where id = 10 lock in share mode ;
Nur eine kurze Anmerkung: Bitte beachten Sie, dass Sie unter InnoDB nicht nur Zeilensperren verwenden, wenn Sie Zeilensperren verwenden möchten. Sehen wir uns noch einmal die Auslösebedingungen von Zeilensperren an (erwähnt). am Anfang):
Exklusive Sperre (Exklusive Sperre) Sperre)
Exklusive Sperre, Schreibsperre, X-Sperre sind alle seine Namen.
Und ich nenne ihn gerne Exklusive Schreibsperre.
Eine exklusive (X) Sperre ermöglicht der Transaktion, die die Sperre hält, das Aktualisieren oder Löschen.
Exklusive (X) Sperren ermöglichen das Aktualisieren oder Löschen der Transaktion, die die Sperre hält.
Exklusiv, dieses Wort. Haben Sie jemals Basketball gespielt? Ich wusste nicht, wie man in der Mittelstufe Basketball spielt. Meine Klassenkameraden sagten zu mir: Du bist so einsam.
Ja, ich bin sehr allein. Genau wie diese exklusive Schreibsperre (exklusive Sperre) ist sie sehr einzigartig.
Wenn eine Transaktion bestimmten Daten eine exklusive Schreibsperre (exklusive Sperre) hinzufügt, kann nur die aktuelle Transaktion die Daten ändern oder löschen.
Andere Transaktionen können nicht gelesen oder geschrieben werden. Da diese Sperre sehr einzigartig ist, müssen Sie warten, bis diese einzigartige Sperre aufgebraucht (freigegeben) ist, bevor andere Transaktionen sie nutzen können.
Die exklusive Schreibsperre (exklusive Sperre) schließt sich also gegenseitig für das Lesen und Schreiben aus und schließt sich gegenseitig für das Schreiben und Schreiben aus.
Lassen Sie mich übrigens vorstellen, wie Sie eine exklusive Sperre (exklusive Schreibsperre) hinzufügen:
Exklusive Sperre auf Tabellenebene, dh exklusive Schreibsperre auf Tabellenebene:
select * from table for update ;
Exklusive Sperre auf Upstream-Ebene ist eine exklusive Schreibsperre auf Zeilenebene:
rrreeBeachten Sie, dass Sie unter InnoDB nicht nur Zeilensperren verwenden, sondern auch die Auslösebedingungen von Zeilensperren noch einmal (am Anfang erwähnt):
Das obige SQL kann eine exklusive Sperre auf Zeilenebene erhalten, da es auf den Index trifft und die ID der Index ist.
Wenn Sie das sehen, wissen Sie vielleicht immer noch nicht genau, was gemeinsame Sperren und exklusive Sperren sind, was Lese-/Lese-Freigabe, gegenseitiger Lese-/Schreibausschluss, gegenseitiger Schreib-/Schreibausschluss usw. ist.
Also müssen wir diese beiden Schlösser noch einmal aus Gottes Sicht betrachten,
rot Transaktionsoperation eins
blauTransaktionsoperation zwei
| Gemeinsame Sperre (gemeinsame Lesesperre) | Exklusive Sperre (exklusive Schreibsperre) |
Ja, kompatibel, gemeinsam lesen | Nein, inkompatibel. Wenn Sie schreiben möchten, müssen Sie warten, bis die gemeinsame Sperre weg ist , nicht kompatibel, es ist exklusiv gesperrt, niemand sonst kann etwas tun |
Das obige ist der detaillierte Inhalt vonBeispiele zur Erläuterung von Shared Locks und Exclusive Locks unter MySQL und InnoDB. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Die Hauptaufgabe von MySQL in Webanwendungen besteht darin, Daten zu speichern und zu verwalten. 1.Mysql verarbeitet effizient Benutzerinformationen, Produktkataloge, Transaktionsunterlagen und andere Daten. 2. Durch die SQL -Abfrage können Entwickler Informationen aus der Datenbank extrahieren, um dynamische Inhalte zu generieren. 3.Mysql arbeitet basierend auf dem Client-Server-Modell, um eine akzeptable Abfragegeschwindigkeit sicherzustellen.

Zu den Schritten zum Erstellen einer MySQL -Datenbank gehören: 1. Erstellen einer Datenbank und Tabelle, 2. Daten einfügen, und 3. Durchführen von Abfragen. Verwenden Sie zunächst die Anweisungen für erstellte und creatEtable, um die Datenbank und Tabelle zu erstellen, und verwenden Sie dann die Anweisung InsertInto, um die Daten einzulegen, und verwenden Sie schließlich die Auswahlanweisung, um die Daten abzufragen.

MySQL ist für Anfänger geeignet, da es einfach zu bedienen und leistungsfähig ist. 1.Mysql ist eine relationale Datenbank und verwendet SQL für CRUD -Operationen. 2. Es ist einfach zu installieren und erfordert, dass das Stammbenutzerkennwort konfiguriert wird. 3.. Verwenden Sie Einfügen, Aktualisieren, Löschen und Wählen Sie, um Datenvorgänge auszuführen. 4. OrderBy, wo und Join kann für komplexe Abfragen verwendet werden. 5. Debugging erfordert die Überprüfung der Syntax und verwenden Sie Erklärungen zur Analyse der Abfrage. 6. Die Optimierungsvorschläge umfassen die Verwendung von Indizes, die Auswahl des richtigen Datentyps und der guten Programmiergewohnheiten.

MySQL ist für Anfänger geeignet, weil: 1) Einfach zu installieren und konfigurieren, 2) Rich Learning Resources, 3) Intuitive SQL -Syntax, 4) leistungsstarke Toolunterstützung. Anfänger müssen jedoch Herausforderungen wie Datenbankdesign, Abfrageoptimierung, Sicherheitsmanagement und Datensicherung überwinden.

Ja, sqlisaprogrammingLuagespezialisierteForDatamanagement.1) Es ist dieklarativ, fokussierte Waagewhattoachieveratherthanhow.2)

Säureattribute umfassen Atomizität, Konsistenz, Isolation und Haltbarkeit und sind der Eckpfeiler des Datenbankdesigns. 1. Atomizität stellt sicher, dass die Transaktion entweder vollständig erfolgreich oder vollständig gescheitert ist. 2. Konsistenz stellt sicher, dass die Datenbank vor und nach einer Transaktion konsistent bleibt. 3. Isolation stellt sicher, dass sich Transaktionen nicht stören. 4. Persistenz stellt sicher, dass Daten nach der Transaktionsuntersuchung dauerhaft gespeichert werden.

MySQL ist nicht nur ein Datenbankverwaltungssystem (DBMS), sondern auch eng mit Programmiersprachen zusammen. 1) Als DBMS wird MySQL verwendet, um Daten zu speichern, zu organisieren und abzurufen und Indizes zu optimieren, können die Abfrageleistung verbessern. 2) Kombinieren Sie SQL mit Programmiersprachen, eingebettet in Python, und unter Verwendung von ORM -Tools wie SQLalchemy kann die Operationen vereinfachen. 3) Die Leistungsoptimierung umfasst Indexierung, Abfrage, Caching, Bibliothek und Tabellenabteilung und Transaktionsmanagement.

MySQL verwendet SQL -Befehle, um Daten zu verwalten. 1. Grundlegende Befehle umfassen Auswahl, Einfügen, Aktualisieren und Löschen. 2. Die erweiterte Verwendung umfasst die Funktionen, Unterabfragen und Aggregate. 3. Häufige Fehler sind Syntax-, Logik- und Leistungsprobleme. 4. Die Optimierungstipps umfassen die Verwendung von Indizes, die Vermeidung von Auswahl* und die Verwendung von Limit.


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Herunterladen der Mac-Version des Atom-Editors
Der beliebteste Open-Source-Editor

PHPStorm Mac-Version
Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

WebStorm-Mac-Version
Nützliche JavaScript-Entwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)