MySQLs "Sperrtabellengröße überschritten" Fehler
MySQL -Benutzer stoßen häufig auf den Fehler "Die Anzahl der Sperren überschreitet die Größe der Sperrtabelle", insbesondere beim Einfügen großer Datensätze in temporäre Tabellen. Dieser Artikel erläutert die Grundursache und bietet wirksame Lösungen.
Der Fehler entsteht typischerweise, wenn eine Abfrage, z. B. eine unter Verwendung einer temporären Tabelle (z. B. SkusBought
aus mehreren Quellen), versucht, eine massive Datenmenge einzufügen. Dies überwältigt die Standardkapazität von MySQL von MySQL. Einfach die Größe der Pufferpool zu erhöhen ist nicht immer eine ausreichende Lösung.
Eine gezieltere Lösung besteht darin, die Variable innodb_buffer_pool_size
mysql zu optimieren. Diese Variable bestimmt den von der InnoDB Storage Engine zugewiesenen Speicher zum zwischen den Daten zugegriffenen Caching. Durch Erhöhen dieses Wertes kann die Datenbank mehr Daten im Speicher halten und die Notwendigkeit einer konstanten Verriegelung und Entsperrung minimieren und so den Fehler auflösen.
Hier erfahren Sie, wie Sie innodb_buffer_pool_size
:
my.cnf
, häufig bei /etc/my.cnf
auf Linux -Systemen). innodb_buffer_pool_size=64M
in der Datei. (Passen Sie den Wert nach Bedarf an; 64 MB ist ein Ausgangspunkt.) service mysqld restart
oder /etc/init.d/mysqld restart
. ordnungsgemäße Einstellung von innodb_buffer_pool_size
sollte das Problem der Sperrtabelle lindern. Denken Sie daran, den Speicherverbrauch mit den Gesamtbedarf der Datenbankleistung auszugleichen. Wenn das Problem weiterhin besteht, sollten Sie eine weitere Optimierung berücksichtigen, z.
Das obige ist der detaillierte Inhalt vonWie kann ich den Fehler 'Die Anzahl der Schlösser überschreiten den Fehler der Sperrtabellengröße' in MySQL fest?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!