So löschen Sie Millionen von MySQL-Zeilen ohne Ausfallzeit
Angesichts eines Fehlers, der zu Millionen doppelter Zeilen führte, finden Sie einen Löschvorgang Eine Strategie, die Ausfallzeiten minimiert, ist entscheidend.
Eine Möglichkeit besteht darin, zahlreiche kleinere Löschabfragen in einer Schleife auszuführen. Dieser Ansatz kann jedoch die Datenbank belasten und den Löschvorgang verlängern.
Eine andere Möglichkeit besteht darin, die vorhandene Tabelle umzubenennen, eine neue leere zu erstellen, eine Bereinigung der umbenannten Tabelle durchzuführen und die Daten dann wieder in die zusammenzuführen Originaltisch. Obwohl diese Methode nur minimale Unterbrechungen mit sich bringt, bringt sie logistische Herausforderungen mit sich, einschließlich potenziellem Datenverlust und der Notwendigkeit einer sorgfältigen Datenzusammenführung.
Eine effizientere Lösung besteht darin, die folgende Abfrage in einer Schleife mit einer kurzen Ruhephase auszuführen zwischen Iterationen:
DELETE FROM `table` WHERE (whatever criteria) ORDER BY `id` LIMIT 1000
Durch die Begrenzung des Löschvorgangs auf jeweils 1000 Zeilen und das Hinzufügen eines kurzen Ruheintervalls ermöglicht diese Technik die Verschachtelung anderer Abfragen und verhindert das Sperren von Tabellen. Mit fortschreitenden Iterationen nimmt die Anzahl der betroffenen Zeilen allmählich ab, bis Null übrig bleibt.
Dieser Ansatz kombiniert Effizienz mit minimaler Ausfallzeit und eignet sich daher zum Löschen großer Zeilenmengen, ohne die Funktionalität der Website oder das Benutzererlebnis zu beeinträchtigen.
Das obige ist der detaillierte Inhalt vonWie lösche ich Millionen von MySQL-Zeilen ohne Ausfallzeit?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!