MYSQL分页limit速度太慢优化方法
生活随笔
收集整理的這篇文章主要介紹了
MYSQL分页limit速度太慢优化方法
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
問題原因
limit 10000,20 的意思掃描滿足條件的 10020 行,扔掉前面的 10000 行,返回最后的 20 行,問題就在這里
原理
利用表的覆蓋索引來加速分頁查詢
我們都知道,利用了索引查詢的語句中如果只包含了那個索引列(覆蓋索引),那么這種情況會查詢很快。
因為利用索引查找有優化算法,且數據就在查詢索引上面,不用再去找相關的數據地址了,這樣節省了很多時間。另外Mysql中也有相關的索引緩存,在并發高的時候利用緩存就效果更好了。
在我們的例子中,我們知道id字段是主鍵,自然就包含了默認的主鍵索引。現在讓我們看看利用覆蓋索引的查詢效果如何:
這次我們之間查詢最后一頁的數據(利用覆蓋索引,只包含id列),如下:
select id from product limit 866613, 20 0.2秒
那么如果我們也要查詢所有列,有兩種方法,一種是id>=的形式,另一種就是利用join,看下實際情況:
SELECT * FROM product WHERE ID > =(select id from product limit 866613, 1) limit 20查詢時間為0.2秒,簡直是一個質的飛躍啊,哈哈
另一種寫法
SELECT * FROM product a JOIN (select id from product limit 866613, 20) b ON a.ID = b.id查詢時間也很短,贊!
?
總結
以上是生活随笔為你收集整理的MYSQL分页limit速度太慢优化方法的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 图片日志:深拷贝和浅拷贝的区别/序列化及
- 下一篇: MySQL中using的用法