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