SQL Server 分頁:LIMIT 與 OFFSET 的替代方法
PostgreSQL 的 LIMIT 和 OFFSET 語法可以有效率地實現結果集分頁。然而,SQL Server 並沒有直接等效的語法。
SQL Server 的分頁方法
從 SQL Server 2012 開始,出現了一個強大的解決方案:
文法:
<code class="language-sql">SELECT email FROM emailTable WHERE user_id=3 ORDER BY Id OFFSET 10 ROWS FETCH NEXT 10 ROWS ONLY;</code>
參數:
ORDER BY
:必需。決定行的排序順序。 OFFSET
:可選。指定要跳過的行數。 FETCH NEXT
:必需。確定在跳過指定行數後要檢索的行數。 範例:
要從 emailTable
表中選擇 user_id
為 3 的第 11 行到第 20 行:
<code class="language-sql">SELECT email FROM emailTable WHERE user_id=3 ORDER BY Id OFFSET 10 ROWS FETCH NEXT 10 ROWS ONLY;</code>
其他說明:
ORDER BY
子句對於分頁功能是必需的。 OFFSET
子句是可選的,允許您跳過特定數量的行。 FETCH NEXT
子句是必需的,它指定偏移後要檢索的行數。 參考:https://www.php.cn/link/26fcf9e127023b55bc1dab3feacf45a8
以上是SQL Server 如何處理沒有 LIMIT 和 OFFSET 的分頁?的詳細內容。更多資訊請關注PHP中文網其他相關文章!