為什麼MySQL在數據庫較大的時候分頁查詢很慢,如何優化?

一葉知秋丿


使用合理的分頁方式以提高分頁的效率


正如樓主所說,分頁查詢在我們的實際應用中非常普遍,也是最容易出問題的查詢場景。比如對於下面簡單的語句,一般想到的辦法是在name,age,register_time字段上創建複合索引。這樣條件排序都能有效的利用到索引,性能迅速提升。

如上例子,當 LIMIT 子句變成 “LIMIT 100000, 50” 時,此時我們會發現,只取50條語句為何會變慢?


原因很簡單,MySQL並不知道第 100000條記錄從什麼地方開始,即使有索引也需要從頭計算一次,因此會感覺非常的慢。

通常,我們在做分頁查詢時,是可以獲取上一頁中的某個數據標誌來縮小查詢範圍的,比如時間,可以將上一頁的最大值時間作為查詢條件的一部分,SQL可以優化為這樣:


若對你有所幫助,歡迎點贊、關注支持哦。

軟件測試開發技術棧


這個得明白mysql的存儲原理 講個例子 一個小區有很多棟 一棟有很多層 一層有很多室 你哪個小區哪一棟那一層都不告訴它 它能一下找到嗎 雖然它也想快點幫你找到


分享到:


相關文章: