Eine effizientere Lösung für SQL Server-Paging: Keyset-Paging
In SQL Server wird Paging normalerweise mit OFFSET implementiert, aber für große Tabellen ist Keyset-Paging eine effizientere Methode. Im Gegensatz zur Rowset-Paginierung, bei der alle vorherigen Zeilen gelesen werden müssen, um zur gewünschten Seite zu gelangen, springt die Keyset-Paginierung direkt zur richtigen Position im Index und verbessert so die Leistung erheblich.
Die Implementierung von Keyset-Paging erfordert die Erstellung eines eindeutigen Index für den erforderlichen Schlüssel. Der Schlüssel kann zusätzliche Spalten enthalten, die für die Abfrage erforderlich sind. Es ist zu beachten, dass diese Methode nicht direkt zu einer bestimmten Seitennummer springen kann. Stattdessen müssen Sie zuerst einen bestimmten Schlüssel finden und dann von dort aus fortfahren.
Ein Vorteil des Keyset-Paging besteht darin, dass es das Problem der „verlorenen Zeile“ vermeidet, das durch das Löschen von Zeilen beim Rowset-Paging verursacht wird. Da Paging auf Schlüsseln basiert, haben Änderungen in der Reihenfolge der Zeilen keinen Einfluss auf die Paging-Logik.
Das Folgende ist ein Beispiel für die Verwendung der Keyset-Paginierung in SQL Server:
<code class="language-sql">SELECT TOP (@numRows) * FROM TableName ORDER BY Id DESC;</code>
Diese Abfrage ruft die erste Seite mit Daten in absteigender Reihenfolge nach der ID-Spalte ab. Um weiter zu paginieren, können Sie den zuletzt empfangenen ID-Wert wie folgt verwenden:
<code class="language-sql">SELECT TOP (@numRows) * FROM TableName WHERE Id < @lastId ORDER BY Id DESC;</code>
Um das Paging nach nicht eindeutigen Spalten zu unterstützen, müssen zusätzliche Spalten sowohl in den ORDER BY
- als auch in den WHERE
-Klauseln enthalten sein. Für ausgewählte Spalten müssen geeignete Indizes erstellt werden, um eine effiziente Ausführung sicherzustellen.
Keyset-Paging bietet eine effizientere Alternative zum OFFSET-Paging für große Datensätze in SQL Server. Es vermeidet unnötige Zeilenlesevorgänge und sorgt für konsistente paginierte Ergebnisse, selbst wenn Daten geändert werden.
Das obige ist der detaillierte Inhalt vonKeyset-Paginierung vs. OFFSET in SQL Server: Ein effizienterer Ansatz?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!