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 ;
Nach dem Login kopieren
Gemeinsame Sperre auf Upstream-Ebene ist eine gemeinsame Lesesperre auf Zeilenebene:
select * from table(表)where id = 10
lock in share mode
;
Nach dem Login kopieren
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
;
Nach dem Login kopieren
Exklusive Sperre auf Upstream-Ebene ist eine exklusive Schreibsperre auf Zeilenebene:
rrree
Beachten 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,
rotTransaktionsoperation eins
blau
Transaktionsoperation zwei
.
Gemeinsame Sperre (gemeinsame Lesesperre)
Exklusive Sperre (exklusive Schreibsperre)
Gemeinsame Sperre (gemeinsame Lesesperre)
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
3. Wenn die exklusive Schreibsperre also nie aufgehoben wird, werden andere Transaktionen dann weiter warten?
Das Gleiche gilt, es wird auf eine Zeitüberschreitung gewartet, um einen Abfragefehler zurückzugeben:
Fügen Sie ein wenig Übung hinzu:
1. Geben Sie immer noch eine exklusive Schreibsperre für bestimmte Daten ohne COMMIT:
2. Gewöhnliche Abfrage ausführen, auswählen:
Sie können sehen, dass die gewöhnliche SELECT-Anweisung normal abgerufen werden kann. Warum? Weil wir es bereits erwähnt haben:
Also muss ich es noch einmal erklären. Der sogenannte gegenseitige Lese-/Schreibausschluss und der gegenseitige Schreib-/Schreibausschluss gelten alle für Sperrressourcen. Wenn es keinen Sperrressourcenwettbewerb gibt, darf es keinen gegenseitigen Ausschluss oder gegenseitigen Ausschluss geben.
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!
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
MySQL ist für Anfänger geeignet, da es einfach zu installieren, leistungsfähig und einfach zu verwalten ist. 1. Einfache Installation und Konfiguration, geeignet für eine Vielzahl von Betriebssystemen. 2. Unterstützung grundlegender Vorgänge wie Erstellen von Datenbanken und Tabellen, Einfügen, Abfragen, Aktualisieren und Löschen von Daten. 3. Bereitstellung fortgeschrittener Funktionen wie Join Operations und Unterabfragen. 4. Die Leistung kann durch Indexierung, Abfrageoptimierung und Tabellenpartitionierung verbessert werden. 5. Backup-, Wiederherstellungs- und Sicherheitsmaßnahmen unterstützen, um die Datensicherheit und -konsistenz zu gewährleisten.
Navicat selbst speichert das Datenbankkennwort nicht und kann das verschlüsselte Passwort nur abrufen. Lösung: 1. Überprüfen Sie den Passwort -Manager. 2. Überprüfen Sie Navicats "Messnot Password" -Funktion; 3.. Setzen Sie das Datenbankkennwort zurück; 4. Kontaktieren Sie den Datenbankadministrator.
Erstellen Sie eine Datenbank mit Navicat Premium: Stellen Sie eine Verbindung zum Datenbankserver her und geben Sie die Verbindungsparameter ein. Klicken Sie mit der rechten Maustaste auf den Server und wählen Sie Datenbank erstellen. Geben Sie den Namen der neuen Datenbank und den angegebenen Zeichensatz und die angegebene Kollektion ein. Stellen Sie eine Verbindung zur neuen Datenbank her und erstellen Sie die Tabelle im Objektbrowser. Klicken Sie mit der rechten Maustaste auf die Tabelle und wählen Sie Daten einfügen, um die Daten einzufügen.
MySQL ist ein Open Source Relational Database Management System. 1) Datenbank und Tabellen erstellen: Verwenden Sie die Befehle erstellte und creatEtable. 2) Grundlegende Vorgänge: Einfügen, aktualisieren, löschen und auswählen. 3) Fortgeschrittene Operationen: Join-, Unterabfrage- und Transaktionsverarbeitung. 4) Debugging -Fähigkeiten: Syntax, Datentyp und Berechtigungen überprüfen. 5) Optimierungsvorschläge: Verwenden Sie Indizes, vermeiden Sie ausgewählt* und verwenden Sie Transaktionen.
Navicat für MariADB kann das Datenbankkennwort nicht direkt anzeigen, da das Passwort in verschlüsselter Form gespeichert ist. Um die Datenbanksicherheit zu gewährleisten, gibt es drei Möglichkeiten, Ihr Passwort zurückzusetzen: Setzen Sie Ihr Passwort über Navicat zurück und legen Sie ein komplexes Kennwort fest. Zeigen Sie die Konfigurationsdatei an (nicht empfohlen, ein hohes Risiko). Verwenden Sie Systembefehlsleitungs -Tools (nicht empfohlen, Sie müssen die Befehlszeilen -Tools beherrschen).
Sie können eine neue MySQL -Verbindung in Navicat erstellen, indem Sie den Schritten folgen: Öffnen Sie die Anwendung und wählen Sie eine neue Verbindung (Strg N). Wählen Sie "MySQL" als Verbindungstyp. Geben Sie die Hostname/IP -Adresse, den Port, den Benutzernamen und das Passwort ein. (Optional) Konfigurieren Sie erweiterte Optionen. Speichern Sie die Verbindung und geben Sie den Verbindungsnamen ein.
MySQL und SQL sind wesentliche Fähigkeiten für Entwickler. 1.MYSQL ist ein Open -Source -Relational Database Management -System, und SQL ist die Standardsprache, die zum Verwalten und Betrieb von Datenbanken verwendet wird. 2.MYSQL unterstützt mehrere Speichermotoren durch effiziente Datenspeicher- und Abruffunktionen, und SQL vervollständigt komplexe Datenoperationen durch einfache Aussagen. 3. Beispiele für die Nutzung sind grundlegende Abfragen und fortgeschrittene Abfragen wie Filterung und Sortierung nach Zustand. 4. Häufige Fehler umfassen Syntaxfehler und Leistungsprobleme, die durch Überprüfung von SQL -Anweisungen und Verwendung von Erklärungsbefehlen optimiert werden können. 5. Leistungsoptimierungstechniken umfassen die Verwendung von Indizes, die Vermeidung vollständiger Tabellenscanning, Optimierung von Join -Operationen und Verbesserung der Code -Lesbarkeit.
Schritte zur Durchführung von SQL in Navicat: Verbindung zur Datenbank herstellen. Erstellen Sie ein SQL -Editorfenster. Schreiben Sie SQL -Abfragen oder Skripte. Klicken Sie auf die Schaltfläche Ausführen, um eine Abfrage oder ein Skript auszuführen. Zeigen Sie die Ergebnisse an (wenn die Abfrage ausgeführt wird).