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 |