MySQL-Abfragen, die die LIMIT-Klausel mit großen Offsets verwenden, können zu erheblichen Leistungsproblemen führen. Um dieser Herausforderung zu begegnen, ziehen Sie die folgende Optimierungstechnik in Betracht:
Anstatt Zeilen direkt mithilfe einer LIMIT-Klausel abzurufen, erstellen Sie eine Indexierungstabelle, die sequentielle Schlüssel den Primärschlüsselwerten in zuordnet die Zieltabelle. Dadurch können Sie Daten mithilfe einer INNER JOIN- und einer WHERE-Klausel effizient abrufen.
Schritte:
Erstellen Sie eine Indexierungstabelle:
CREATE TABLE seq ( seq_no int NOT NULL AUTO_INCREMENT, id int NOT NULL, PRIMARY KEY(seq_no), UNIQUE(id) );
Bevölkern Sie die Indexierungstabelle:
TRUNCATE seq; INSERT INTO seq (id) SELECT id FROM mytable ORDER BY id;
Daten aus der Zieltabelle abrufen:
SELECT mytable.* FROM mytable INNER JOIN seq USING(id) WHERE seq.seq_no BETWEEN 1000000 AND 1000999;
Von Mit diesem Ansatz steigern Sie die Leistung von Abfragen mit großen LIMIT-Offsets erheblich und ermöglichen so einen effizienten Datenabruf.
Das obige ist der detaillierte Inhalt vonWie optimiere ich MySQL-Abfragen mit großen LIMIT-Offsets?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!