Heim > Datenbank > MySQL-Tutorial > Wie sperre ich mehrere Tabellen in MySQL?

Wie sperre ich mehrere Tabellen in MySQL?

王林
Freigeben: 2023-09-04 11:13:11
nach vorne
772 Leute haben es durchsucht

Wie sperre ich mehrere Tabellen in MySQL?

Mit dem Befehl LOCK TABLES können Sie mehrere Tabellensperren implementieren. Die Syntax lautet wie folgt:

LOCK TABLES yourTableName1 WRITE;
LOCK TABLES yourTableName2 WRITE;
LOCK TABLES yourTableName3 WRITE;
LOCK TABLES yourTableName4 WRITE;
.
.
.
N;
Nach dem Login kopieren

Die Tabellensperre ist nicht transaktionssicher, sie schreibt implizit zuerst die aktive Transaktion fest, bevor versucht wird, die zweite Tabelle zu sperren.

Angenommen, ich habe eine Tabelle OrderDemo -

mysql> create table OrderDemo
   -> (
   -> OrderId int NOT NULL AUTO_INCREMENT PRIMARY KEY,
   -> OrderPrice int,
   -> OrderDatetime datetime
   -> );
Query OK, 0 rows affected (0.66 sec)
Nach dem Login kopieren

Hier ist die Abfrage zum Sperren der Tabellen OrderDemo und utfdemo. utfdemo ist bereits in der Beispieldatenbank vorhanden. Die Abfrage lautet wie folgt:

mysql> LOCK TABLES OrderDemo WRITE;
Query OK, 0 rows affected (0.03 sec)
mysql> LOCK TABLES utfdemo WRITE;
Query OK, 0 rows affected (0.07 sec)
Nach dem Login kopieren

Jetzt wird die Tabelle der Sitzung gesperrt. Wenn Sie versuchen, eine Tabelle zu erstellen, erhalten Sie eine Fehlermeldung.

Der Fehler lautet wie folgt:

mysql> create table LockTableDemo
   -> (
   -> UserId int,
   -> UserName varchar(10)
   -> );
ERROR 1100 (HY000): Table 'LockTableDemo' was not locked with LOCK TABLES
mysql> create table UserIformation
   -> (
   -> UserId int,
   -> UserName varchar(10)
   -> );
ERROR 1100 (HY000): Table 'UserIformation' was not locked with LOCK TABLES
Nach dem Login kopieren

Um dieses Problem zu beheben, müssen Sie MySQL neu starten.

Das obige ist der detaillierte Inhalt vonWie sperre ich mehrere Tabellen in MySQL?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:tutorialspoint.com
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage