激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - Mysql - MySQL分頁分析原理及提高效率

MySQL分頁分析原理及提高效率

2020-07-27 17:26MYSQL教程網 Mysql

這篇文章主要介紹了MySQL分頁分析原理及提高效率的相關資料,需要的朋友可以參考下

MySQL分頁分析原理及提高效率

PERCONA PERFORMANCE CONFERENCE 2009上,來自雅虎的幾位工程師帶來了一篇”Efficient Pagination Using MySQL“的報告,有很多亮點,本文是在原文基礎上的進一步延伸。

首先看一下分頁的基本原理:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
MySQL> explain SELECT * FROM message ORDER BY id DESC LIMIT 10000, 20\G
***************** 1. row **************
id: 1
select_type: SIMPLE
table: message
type: index
possible_keys: NULL
key: PRIMARY
key_len: 4
ref: NULL
rows: 10020
Extra:
1 row in set (0.00 sec)

limit 10000,20的意思掃描滿足條件的10020行,扔掉前面的10000行,返回最后的20行,問題就在這里,如果是limit 100000,100,需要掃描100100行,在一個高并發的應用里,每次查詢需要掃描超過10W行,性能肯定大打折扣。文中還提到limit n性能是沒問題的,因為只掃描n行。

文中提到一種”clue”的做法,給翻頁提供一些”線索”,比如還是SELECT * FROM message ORDER BY id DESC,按id降序分頁,每頁20條,當前是第10頁,當前頁條目id最大的是9527,最小的是9500,如果我們只提供”上一頁”、”下一頁”這樣的跳轉(不提供到第N頁的跳轉),那么在處理”上一頁”的時候SQL語句可以是:

?
1
SELECT * FROM message WHERE id > 9527 ORDER BY id ASC LIMIT 20;

處理”下一頁”的時候SQL語句可以是:

?
1
SELECT * FROM message WHERE id < 9500 ORDER BY id DESC LIMIT 20;

不管翻多少頁,每次查詢只掃描20行。

缺點是只能提供”上一頁”、”下一頁”的鏈接形式,但是我們的產品經理非常喜歡”<上一頁 1 2 3 4 5 6 7 8 9 下一頁>”這樣的鏈接方式,怎么辦呢?

如果LIMIT m,n不可避免的話,要優化效率,只有盡可能的讓m小一下,我們擴展前面的”clue”做法,還是SELECT * FROM message ORDER BY id DESC,按id降序分頁,每頁20條,當前是第10頁,當前頁條目id最大的是9527,最小的是9500,比如要跳到第8頁,我看的SQL語句可以這樣寫:

?
1
SELECT * FROM message WHERE id > 9527 ORDER BY id ASC LIMIT 20,20;

跳轉到第13頁:

?
1
SELECT * FROM message WHERE id < 9500 ORDER BY id DESC LIMIT 40,20;

原理還是一樣,記錄住當前頁id的最大值和最小值,計算跳轉頁面和當前頁相對偏移,由于頁面相近,這個偏移量不會很大,這樣的話m值相對較小,大大減少掃描的行數。其實傳統的limit m,n,相對的偏移一直是第一頁,這樣的話越翻到后面,效率越差,而上面給出的方法就沒有這樣的問題。

注意SQL語句里面的ASC和DESC,如果是ASC取出來的結果,顯示的時候記得倒置一下。

已在60W數據總量的表中測試,效果非常明顯。

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

原文鏈接:http://blog.csdn.net/leeyisoft/article/details/8246003

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲人成电影在线 | 精品亚洲国产视频 | 日韩色视频| 99精品视频在线观看免费播放 | 国产精品视频二区不卡 | 欧美成人性生活片 | 射逼网站| 高清在线观看av | 国产亚洲精品久久777777 | 成人毛片在线 | 在线成人免费观看视频 | 黄色大片网站在线观看 | 久久精品视频1 | 91短视频在线视频 | 久久人人av | 国产影视| 久久露脸国语精品国产91 | 国内精品久久久久久久影视红豆 | 亚洲人成网在线观看 | 逼片 | 五月婷婷天堂 | 国产品久久 | 免费毛片随便看 | 亚洲一区二区三区精品在线观看 | 国产小视频一区 | 国产人成精品一区二区三 | 国产无限资源在线观看 | 欧美一级做一级爱a做片性 久久久资源网 | 精品亚洲视频在线观看 | 久久99亚洲精品久久99果 | www.91sese| 欧洲精品久久 | 欧美精品成人一区二区在线观看 | 亚洲性在线视频 | 国内精品一级毛片免费看 | 成人免费毛片网站 | 久久久久久久久浪潮精品 | 精品久久久久久综合日本 | 亚洲午夜精品视频 | 日韩视频―中文字幕 | 亚洲一区成人在线 |