程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> Advanced Pagination for MySQL(mysql高等分頁)

Advanced Pagination for MySQL(mysql高等分頁)

編輯:MySQL綜合教程

Advanced Pagination for MySQL(mysql高等分頁)。本站提示廣大學習愛好者:(Advanced Pagination for MySQL(mysql高等分頁))文章只能為提供參考,不一定能成為您想要的結果。以下是Advanced Pagination for MySQL(mysql高等分頁)正文


在葉子的文章裡談到了應用inner join 從而削減了對page的掃描也就是削減了所謂的回表 例如:


SELECT * FROM `t1` INNER JOIN ( SELECT id FROM `t1`ORDER BY id DESC LIMIT 935500,10) t2 USING (id)

經由過程直接對id的操作 而不是整張表的掃描 經由過程id 的join 抓出相符前提id 然後經由過程ID 再去做數據的抓取。如許就防止了對不須要的頁面的掃描。

不外如許也不是最好的辦法 還可以經由過程對id 的 range加倍減少規模 例如:

我們要分100筆記錄分一頁 可以寫成


$page_size=100 select * from t where id > 99 order by id asc limit $page_size ; select * from  t where id >199 order by id asc limit $page_size;

盡可能防止limit M,N 這類寫法 mysql在對M值很年夜 而offset很小的時刻的處置方法很不人道化 ,所以盡可能不要應用offset來獲得特定行數。

在這裡有一個成績 好比依據不是獨一索引的column分頁 那末能夠存在一個成績,例如一個列column1存在11個key=100的值 那末你應用limit N 以後取到的min value照樣統一個值
這類情形若何處置? 給個例子:

好比要每10筆記錄分一頁


select * from t  order by column1 desc  limit 10

留意這裡取到的min value照樣100 (11個持續的100) 對上面的分頁會發生影響,若何處置?

雅虎給出的計劃異常好 取一個extra的column 例如PK 或許unique index key 例如:


select * from t  order by column1 desc, id desc   limit 10 -- 第一個頁
select * from t  where column1 <=minvalue_col1 and (id < minvalue_id or column1 < minvalue_col1) limit 10  ---第二個頁

如許就確保了獨一性 包管了每頁的數據不會反復 思惟就是經由過程add一個獨一的extra 獲得這個extra的界限值 聯合range column來停止分頁。

這個SQL 還能被優化成:


SELECT m2.* FROM t m1, t m2  WHERE m1.id = m2.id  AND m1.column1 <= minvalue_col1
AND (m1.id < minvalue_id OR m1.column1 < minvalue_col1)  ORDER BY m1.column1 DESC, m1.id DESC  LIMIT 10;

焦點思惟: 經由過程extra過濾 合營ID掃描 防止年夜量的回表操作 如許就到達了要取若干條 就掃描若干條 (in page)

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved