在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中文網其他相關文章!