首頁 >後端開發 >php教程 >如何在具有偏移量和限制的 MySQL 分頁中尋找結果總數?

如何在具有偏移量和限制的 MySQL 分頁中尋找結果總數?

Patricia Arquette
Patricia Arquette原創
2024-10-23 10:33:02499瀏覽

How Can I Find the Total Count of Results in MySQL Pagination with Offset and Limit?

在MySQL 中尋找具有偏移和限制的總結果

分頁允許使用者以可管理的區塊的形式瀏覽大型資料集。但是,確定總頁數需要知道結果總數。當使用偏移量和限制進行分頁時,運行相同的查詢兩次似乎效率很低,一次有限制,一次沒有限制。

SQL_CALC_FOUND_ROWS:解決方案

要解決這個問題,MySQL提供了一個特殊的關鍵字:SQL_CALC_FOUND_RO。透過將此關鍵字新增至查詢的開頭,MySQL 將計算並儲存在沒有 LIMIT 子句的情況下傳回的總行數。

範例查詢:

<code class="sql">SELECT SQL_CALC_FOUND_ROWS * 
FROM table_name 
WHERE category_id = '1' 
ORDER BY date_created DESC
LIMIT 10 OFFSET 20;</code>

擷取結果總數:

執行上述查詢後,您可以使用下列PHP程式碼檢索結果總數:

<code class="php">$totalRows = $db->query('SELECT FOUND_ROWS() AS total')->row()->total;</code>

SQL_CALC_FOUND_ROWS 的好處:

  • 提高效率:
  • 提高效率:不需執行兩次查詢。
  • 準確度: 即使基礎資料在查詢之間發生變化,也能確保總計數正確。
簡單性: 使用單一關鍵字即可輕鬆實現。

以上是如何在具有偏移量和限制的 MySQL 分頁中尋找結果總數?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn