Heim >Datenbank >MySQL-Tutorial >Wie kann ich die Gesamtzeilenzahl mit Paginierung in MySQL effizient abrufen?
Ermitteln der Gesamtzeilenanzahl mit LIMIT
Beim Ausführen von SQL-Abfragen mit Paginierung ist es häufig erforderlich, die Gesamtzeilenanzahl zu ermitteln. Normalerweise erfordert dies, dass die Abfrage zweimal ausgeführt wird, einmal ohne die LIMIT-Klausel, um die Gesamtzahl zu ermitteln.
Es gibt jedoch eine effizientere Möglichkeit, dies zu erreichen, ohne auf mehrere Abfragen zurückgreifen zu müssen.
SQL_CALC_FOUND_ROWS
Seit MySQL 4.0.0 kann die Option SQL_CALC_FOUND_ROWS verwendet werden. Es weist MySQL an, die Gesamtzeilenanzahl zu berechnen, auch wenn eine LIMIT-Klausel vorhanden ist.
Um diese Option zu verwenden, fügen Sie sie einfach nach der SELECT-Anweisung in der Hauptabfrage hinzu. Führen Sie dann eine separate Abfrage aus, um die Zeilenanzahl mit der Funktion FOUND_ROWS() abzurufen.
SELECT SQL_CALC_FOUND_ROWS name, email FROM users WHERE name LIKE 'a%' LIMIT 10; SELECT FOUND_ROWS();
Hinweis: Obwohl SQL_CALC_FOUND_ROWS zwei Abfragen erfordert, ist es im Allgemeinen schneller als die zweimalige Ausführung der Hauptabfrage . Ab MySQL 8.0.17 ist diese Option jedoch veraltet und wird in einer zukünftigen Version entfernt.
Alternative: COUNT()
Als Alternative: Sie Sie können die Funktion COUNT() in einer separaten Abfrage verwenden, um die Gesamtanzahl der Zeilen zu ermitteln.
SELECT COUNT(*) FROM tbl_name WHERE id > 100;
Diese Methode erfordert ebenfalls zwei Abfragen, ist jedoch ein neuerer und bevorzugter Ansatz.
Das obige ist der detaillierte Inhalt vonWie kann ich die Gesamtzeilenzahl mit Paginierung in MySQL effizient abrufen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!