《Mysql學(xué)習(xí)Advanced Pagination for MySQL(mysql高級(jí)分頁(yè))》要點(diǎn):
本文介紹了Mysql學(xué)習(xí)Advanced Pagination for MySQL(mysql高級(jí)分頁(yè)),希望對(duì)您有用。如果有疑問(wèn),可以聯(lián)系我們。
MYSQL學(xué)習(xí)在葉子的文章里談到了使用inner join 從而減少了對(duì)page的掃描也便是減少了所謂的回表 例如:
MYSQL學(xué)習(xí)通過(guò)直接對(duì)id的操作 而不是整張表的掃描 通過(guò)id 的join 抓出符合條件id 然后通過(guò)ID 再去做數(shù)據(jù)的抓取.這樣就避免了對(duì)不必要的頁(yè)面的掃描.
MYSQL學(xué)習(xí)不過(guò)這樣也不是最佳的辦法 還可以通過(guò)對(duì)id 的 range更加縮小范圍 例如:
MYSQL學(xué)習(xí)我們要分100條記錄分一頁(yè) 可以寫成
MYSQL學(xué)習(xí)盡量避免limit M,N 這種寫法 mysql在對(duì)M值很大 而offset很小的時(shí)候的處置方式很不人性化 ,所以盡量不要使用offset來(lái)取得特定行數(shù).
MYSQL學(xué)習(xí)在這里有一個(gè)問(wèn)題 好比根據(jù)不是唯一索引的column分頁(yè) 那么可能存在一個(gè)問(wèn)題,例如一個(gè)列column1存在11個(gè)key=100的值 那么你使用limit N 之后取到的min value還是同一個(gè)值
這種情況如何處理? 給個(gè)例子:
MYSQL學(xué)習(xí)好比要每10條記錄分一頁(yè)
MYSQL學(xué)習(xí)注意這里取到的min value還是100 (11個(gè)連續(xù)的100) 對(duì)下面的分頁(yè)會(huì)發(fā)生影響,如何處理?
MYSQL學(xué)習(xí)雅虎給出的方案非常好 取一個(gè)extra的column 例如PK 或者unique index key 例如:
MYSQL學(xué)習(xí)這樣就確保了唯一性 保證了每頁(yè)的數(shù)據(jù)不會(huì)重復(fù) 思想就是通過(guò)add一個(gè)唯一的extra 取得這個(gè)extra的界限值 結(jié)合range column來(lái)進(jìn)行分頁(yè).
MYSQL學(xué)習(xí)這個(gè)SQL 還能被優(yōu)化成:
MYSQL學(xué)習(xí)核心思想: 通過(guò)extra過(guò)濾 配合ID掃描 避免大量的回表操作 這樣就到達(dá)了要取多少條 就掃描多少條 (in page)
歡迎參與《Mysql學(xué)習(xí)Advanced Pagination for MySQL(mysql高級(jí)分頁(yè))》討論,分享您的想法,維易PHP學(xué)院為您提供專業(yè)教程。
轉(zhuǎn)載請(qǐng)注明本頁(yè)網(wǎng)址:
http://www.snjht.com/jiaocheng/13974.html