国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

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

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

服務器之家 - 數據庫 - Mysql - Advanced Pagination for MySQL(mysql高級分頁)

Advanced Pagination for MySQL(mysql高級分頁)

2020-06-21 17:52MYSQL教程網 Mysql

看到葉金榮的一篇關于mysql分頁的文章,結合雅虎之前發的一篇PDF 談談自己的看法

在葉子的文章里談到了使用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)

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 免费在线观看黄色网址 | 无码日韩精品一区二区免费 | 三级无遮挡污在线观看 | 日本中文字幕在线看 | 久久久极品 | 亚洲欧美精品 | 天天操夜夜爽 | 欧美一级黄色片网站 | 亚洲欧美综合 | 欧美精品综合 | 免费一级毛片电影 | 国产韩国精品一区二区三区 | 国产片性视频免费播放 | jizz欧美大片 | 来个毛片 | 欧美视频精品 | 伊人伊成久久人综合网站 | 久久成人免费 | 亚洲精品无 | 久久久久久久免费 | 久久久久久久久久久久久大色天下 | 中文字幕视频在线 | 大象视频成人在线观看 | 久久精品国产一区二区电影 | 九九热免费精品视频 | 欧美在线不卡 | 黄色免费av | 午夜精品久久久久久 | 最新国产在线 | 国产91久久久久蜜臀青青天草二 | 亚洲一区二区三区四区的 | 久久久精品网站 | 午夜午夜精品一区二区三区文 | 久久综合九色 | 欧美一区二区三区在线观看 | 久久xxx | 亚洲成人伦理 | 日韩精品一区二区三区四区五区 | 在线国产一区二区 | 激情欧美一区二区三区中文字幕 | 成人一区二区三区 |