」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 如何從 MySQL 有效率地檢索總計數和分頁結果?

如何從 MySQL 有效率地檢索總計數和分頁結果?

發佈於2024-12-21
瀏覽:508

How Can I Efficiently Retrieve Both Total Count and Paginated Results from MySQL?

MySQL 分頁:高效檢索結果和總計數

在MySQL 中實現分頁時,通常的做法是執行兩個單獨的查詢:一到取得結果總數,另一個限制取得的記錄。這種稱為雙重查詢的方法對於大型資料集可能效率低。

然而,問題是是否可以在單一查詢中檢索總結果計數並限制結果。雖然沒有直接的方法來實現此目的,但有兩種替代方法可用:

SQL_CALC_FOUND_ROWS 和FOUND_ROWS()

SQL_CALC_FOUND_ROWS 和FOUND_ROWS()

您可以使用SQL_CALC_FOUND_ROWS 而不是雙重查詢和FOUND_ROWS() 函數可以實現類似的結果。使用 SQL_CALC_FOUND_ROWS 的查詢在限制查詢之前,而 FOUND_ROWS() 呼叫會取得總計數。

SELECT SQL_CALC_FOUND_ROWS * FROM `table` WHERE `some_condition`;
SELECT FOUND_ROWS();

SELECT SQL_CALC_FOUND_ROWS * FROM `table` WHERE `some_condition `; SELECT FOUND_ROWS();

注意: 此方法有一個潛在的缺點。 MySQL 有一個錯誤,在使用此技術時會影響 ORDER BY 查詢,使其在大型表上速度變慢。

快取計數

另一個解決方案是快取總計數在特定的持續時間內。這種方法無需單獨查詢來獲取計數,同時保持效率。

範例:

SET @count = (SELECT COUNT(*) FROM `table` WHERE `some_condition`);
擷取計數並將其快取10 分鐘:

SET @count = (SELECT COUNT(*) FROM `table` WHERE `some_condition`);
SET @count = (SELECT COUNT(*) FROM `table` WHERE `some_condition`);
後續查詢時,請使用快取的計數:

SELECT * FROM `table` WHERE `some_condition` LIMIT 0, 10;

How Can I Efficiently Retrieve Both Total Count and Paginated Results from MySQL?
快取計數可顯著提高效能,特別是對於經常造訪的頁面。雖然它不是單查詢解決方案,但它實現了相同的結果,同時比雙查詢更有效率。

最新教學 更多>
  • 為什麼PHP的DateTime :: Modify('+1個月')會產生意外的結果?
    為什麼PHP的DateTime :: Modify('+1個月')會產生意外的結果?
    使用php dateTime修改月份:發現預期的行為在使用PHP的DateTime類時,添加或減去幾個月可能並不總是會產生預期的結果。正如文檔所警告的那樣,“當心”這些操作的“不像看起來那樣直觀。 ; $ date->修改('1個月'); //前進1個月 echo $ date->...
    程式設計 發佈於2025-04-15
  • Python不會對超範圍子串切片報錯的原因
    Python不會對超範圍子串切片報錯的原因
    在python中用索引切片範圍:二重性和空序列索引單個元素不同,該元素會引起錯誤,切片在序列的邊界之外沒有。 這種行為源於索引和切片之間的基本差異。索引一個序列,例如“示例” [3],返回一個項目。但是,切片序列(例如“示例” [3:4])返回項目的子序列。 索引不存在的元素時,例如“示例” [9...
    程式設計 發佈於2025-04-15
  • 你應避免的SS操作技巧
    你應避免的SS操作技巧
    嘿!自上一篇文章以來已經有一段時間了,我錯過了與大家建立聯繫。我很高興能回來並為您的Web開發旅程分享一些有用的技巧! 今天,讓我們探索。希望您發現這些見解有幫助!我們走吧 ? 1。過於特定的選擇器 編寫高度特定的選擇器可以使您的CSS難以管理和調試。使選擇器簡單且可重複。 避免: # ...
    程式設計 發佈於2025-04-15
  • 如何限制動態大小的父元素中元素的滾動範圍?
    如何限制動態大小的父元素中元素的滾動範圍?
    在交互式接口中實現垂直滾動元素的CSS高度限制問題:考慮一個佈局,其中我們具有與用戶垂直滾動一起移動的可滾動地圖div,同時與固定的固定sidebar保持一致。但是,地圖的滾動無限期擴展,超過了視口的高度,阻止用戶訪問頁面頁腳。 $("#map").css({ margin...
    程式設計 發佈於2025-04-15
  • 如何實時捕獲和流媒體以進行聊天機器人命令執行?
    如何實時捕獲和流媒體以進行聊天機器人命令執行?
    在開發能夠執行命令的chatbots的領域中,實時從命令執行實時捕獲Stdout,一個常見的需求是能夠檢索和顯示標準輸出(stdout)在cath cath cant cant cant cant cant cant cant cant interfaces in Chate cant inter...
    程式設計 發佈於2025-04-15
  • 如何在無序集合中為元組實現通用哈希功能?
    如何在無序集合中為元組實現通用哈希功能?
    在未訂購的集合中的元素要糾正此問題,一種方法是手動為特定元組類型定義哈希函數,例如: template template template 。 struct std :: hash { size_t operator()(std :: tuple const&tuple)const {...
    程式設計 發佈於2025-04-15
  • 如何使用Go HTTP客戶端阻止重定向?
    如何使用Go HTTP客戶端阻止重定向?
    與GO http client 返回重定的返回時,請忽略httpiry的行為以毫無疑問何,ive httpecters的行為恢復很高,因此不需要特定用例。這是實現此功能的一種簡單有效的方法: http.client的checkredirect函數優先於默認的重定向跟隨行為。通過自定義此功能,您...
    程式設計 發佈於2025-04-15
  • 如何將MySQL數據庫添加到Visual Studio 2012中的數據源對話框中?
    如何將MySQL數據庫添加到Visual Studio 2012中的數據源對話框中?
    在Visual Studio 2012 儘管已安裝了MySQL Connector v.6.5.4,但無法將MySQL數據庫添加到實體框架的“ DataSource對話框”中。為了解決這一問題,至關重要的是要了解MySQL連接器v.6.5.5及以後的6.6.x版本將提供MySQL的官方Visual...
    程式設計 發佈於2025-04-15
  • 版本5.6.5之前,使用current_timestamp與時間戳列的current_timestamp與時間戳列有什麼限制?
    版本5.6.5之前,使用current_timestamp與時間戳列的current_timestamp與時間戳列有什麼限制?
    在時間戳列上使用current_timestamp或MySQL版本中的current_timestamp或在5.6.5 此限制源於遺留實現的關注,這些限制需要對當前的_timestamp功能進行特定的實現。 創建表`foo`( `Productid` int(10)unsigned not ...
    程式設計 發佈於2025-04-15
  • 如何將PANDAS DataFrame列轉換為DateTime格式並按日期過濾?
    如何將PANDAS DataFrame列轉換為DateTime格式並按日期過濾?
    Transform Pandas DataFrame Column to DateTime FormatScenario:Data within a Pandas DataFrame often exists in various formats, including strings.使用時間數據時...
    程式設計 發佈於2025-04-15
  • 為什麼我在Silverlight Linq查詢中獲得“無法找到查詢模式的實現”錯誤?
    為什麼我在Silverlight Linq查詢中獲得“無法找到查詢模式的實現”錯誤?
    查詢模式實現缺失:解決“無法找到”錯誤在Silverlight應用程序中,嘗試使用LINQ建立LINQ連接以錯誤而實現的數據庫”,無法找到查詢模式的實現。”當省略LINQ名稱空間或查詢類型缺少IEnumerable 實現時,通常會發生此錯誤。 解決問題來驗證該類型的質量是至關重要的。在此特定實例...
    程式設計 發佈於2025-04-15
  • 為什麼我的CSS背景圖像出現?
    為什麼我的CSS背景圖像出現?
    故障排除:CSS背景圖像未出現 ,您的背景圖像儘管遵循教程說明,但您的背景圖像仍未加載。圖像和样式表位於相同的目錄中,但背景仍然是空白的白色帆布。 而不是不棄用的,您已經使用了CSS樣式: bockent {背景:封閉圖像文件名:背景圖:url(nickcage.jpg); 如果您的html,cs...
    程式設計 發佈於2025-04-15
  • 如何在JavaScript對像中動態設置鍵?
    如何在JavaScript對像中動態設置鍵?
    在嘗試為JavaScript對象創建動態鍵時,如何使用此Syntax jsObj['key' i] = 'example' 1;不工作。正確的方法採用方括號: jsobj ['key''i] ='example'1; 在JavaScript中,數組是一...
    程式設計 發佈於2025-04-15
  • 如何在其容器中為DIV創建平滑的左右CSS動畫?
    如何在其容器中為DIV創建平滑的左右CSS動畫?
    通用CSS動畫,用於左右運動 ,我們將探索創建一個通用的CSS動畫,以向左和右移動DIV,從而到達其容器的邊緣。該動畫可以應用於具有絕對定位的任何div,無論其未知長度如何。 問題:使用左直接導致瞬時消失 更加流暢的解決方案:混合轉換和左 [並實現平穩的,線性的運動,我們介紹了線性的轉換。...
    程式設計 發佈於2025-04-15
  • Python中何時用"try"而非"if"檢測變量值?
    Python中何時用"try"而非"if"檢測變量值?
    使用“ try“ vs.” if”來測試python 在python中的變量值,在某些情況下,您可能需要在處理之前檢查變量是否具有值。在使用“如果”或“ try”構建體之間決定。 “ if” constructs result = function() 如果結果: 對於結果: ...
    程式設計 發佈於2025-04-15

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3