亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MySQL > 正文

在MySQL中使用LIMIT進行分頁的方法

2024-07-24 13:07:15
字體:
來源:轉載
供稿:網友

這篇文章主要介紹了在MySQL中使用LIMIT進行分頁的方法,作者列舉出了三種方法,并且針對跳頁等常見問題做出了提示,需要的朋友可以參考下

今天看一個水友說他的MySQL現在變的很慢。問什么情況時。說單表超過2個G的一個MyISAM。真垃圾的回答方式。

簡單答復:換一個強勁的服務器。換服務器很管用的:)

………

最終讓取到慢查詢:

 

  
  1. SELECT * FROM pw_gbook WHERE uid='N' ORDER BY postdate DESC LIMIT N,N; 
  2.  
  3. SELECT * FROM pw_gbook WHERE uid='N' ORDER BY postdate DESC LIMIT N,N; 

如:

 

 
  1. SELECT * FROM pw_gbook WHERE uid='48' ORDER BY postdate DESC LIMIT 1275480,20; 
  2.  
  3. SELECT * FROM pw_gbook WHERE uid='48' ORDER BY postdate DESC LIMIT 1275480,20; 

看到這個語句我都吐血了(BT的PHPWIND分頁啊,這個語句是PHP初學者寫出來的還正常,但PHPWIND那么成熟的社區了還有這樣的問題)。

我這里簡單說一下LIMIT的原理。這里以LIMIT N,M為基礎:LIMIT首先要找查N+M行,然后從N行處,取M行。那么這樣的SQL對一次查詢1275500一個操作應該是一個昂貴的開銷。對于LIMIT這類的優化,第一個目標就是讓N變的盡可能的小或是不用。

怎么才能使這個N盡可能小呢。我們能做的其實就是用相對的值,給分頁一個提示。如現在我們看的是第5頁,看完看想看第6頁,第6頁同樣顯示是20條記錄。我們就可以想到,以這個例子為準:我們可以肯定的是第6頁的日值應小于第5頁的,如果第5頁的最小日值為:2009-11-4,那我們就可以用:

 

 
  1. SELECT * FROM pw_gbook WHERE uid='48' and postdate<'2009-11-1' ORDER BY postdate DESC LIMIT 20; 
  2.  
  3. SELECT * FROM pw_gbook WHERE uid='48' and postdate<'2009-11-1' ORDER BY postdate DESC LIMIT 20; 

這樣來查詢第6頁的內容。同樣對于查看第4頁的內容(假設第5頁的最大日期為:2009-11-3)則第4頁的內容為:

 

 
  1. SELECT * FROM pw_gbook WHERE uid='48' and postdate>'2009-11-3' ORDER BY postdate DESC LIMIT 20; 
  2.  
  3.  
  4. SELECT * FROM pw_gbook WHERE uid='48' and postdate>'2009-11-3' ORDER BY postdate DESC LIMIT 20; 

這是一個基本的思想。接下來討論一下怎么展現的問題。

再說一下這種業務的SQL怎么實現:對于分頁的展示可以用多用類型。這里說三種常用的類型:

第一種:顯示“上一頁” “下一頁”這種類型

這種方式相對簡單也就出現了我們看到那種SQL不思考的寫法。合理的做法:

第一頁:

 

 
  1. SELECT * FROM pw_gbook WHERE uid='48' ORDER BY postdate DESC LIMIT 20; 
  2.  
  3. SELECT * FROM pw_gbook WHERE uid='48' ORDER BY postdate DESC LIMIT 20; 

第二頁:根據第一頁的postdate進行查詢如:

SELECT * FROM pw_gbook WHERE uid='48' and postdate<'2009-11-3' ORDER BY postdate DESC LIMIT 20;

SELECT * FROM pw_gbook WHERE uid='48' and postdate<'2009-11-3' ORDER BY postdate DESC LIMIT 20;

為什么說這個簡單呢,這個不存在跳頁的問題。接下來這種就存在一個跳頁的問題了。

第二種:顯示 “ 1,2,3,4,5…”

第一頁: 還是以第一頁的方式實現:

 

 
  1. SELECT * FROM pw_gbook WHERE uid='48' ORDER BY postdate DESC LIMIT 20; 
  2.  
  3. SELECT * FROM pw_gbook WHERE uid='48' ORDER BY postdate DESC LIMIT 20; 

第二頁:和原來一樣。如果跳頁,如從第二頁跳到第5頁,這里有一個第二頁的最小日期為:2009-11-3(假設值,可以由第二頁的程序查詢得到),第二到第5,差2頁,每頁20條記錄,那么就可以用:

 

 
  1. SELECT * FROM pw_gbook WHERE uid='48' and postdate<'2009-11-3' ORDER BY postdate DESC LIMIT 40,20; 
  2.  
  3.  
  4. SELECT * FROM pw_gbook WHERE uid='48' and postdate<'2009-11-3' ORDER BY postdate DESC LIMIT 40,20; 

看到這里明白為什么大型網站的分頁不是一下標識出來完了,讓都能點了吧。也不會給你一個框讓你輸入一個頁跳過去了。如果跳的頁面過多,也就存在N值過大的問題了。所以要想辦法必免。

第三種:顯示 “1,2,3,4,5,…. 末頁” 或是 “首頁,<<100,101,102,103 >>末頁”

這里有一個特殊的一地方:

別的頁面的跳轉的上面一樣。這里就加一個末頁,這里又分兩種情況,如果知道最后一頁是多少頁,也就知道了前一頁的最小日期(分頁提示值),這樣就可以用上面的方法查看最后一頁的內容(會出現不足20條的現象),另一種,我就不知道最后是第幾頁,我就是想看看最后什么樣子,那么就可以用(一定是顯示20條):

 

 
  1. SELECT * FROM pw_gbook WHERE uid='48' ORDER BY postdate ASC limit 20; 
  2.  
  3. SELECT * FROM pw_gbook WHERE uid='48' ORDER BY postdate ASC limit 20; 

首頁這里就不在說了。

具體怎么實現搞明白了,就可以做PHP代碼的修改了。稍稍修改一下,就會帶來意想不到的效果。

這里只是一個通用的分頁處理方法。不同的業務有可能還有不同的方法處理。如果在條件可能和情況可以考用:between … and .. 帶代替limit分頁操作。

第三種方法:

簡單的邏輯轉換。

 

 
  1. SELECT * FROM pw_gbook WHERE uid='48' ORDER BY postdate DESC LIMIT 1275480,20; 
  2.  
  3. SELECT * FROM pw_gbook WHERE uid='48' ORDER BY postdate DESC LIMIT 1275480,20; 

轉換成:

 

 
  1. SELECT * FROM pw_gbook WHERE id>1275480 and uid='48' ORDER BY postdate DESC LIMIT 20; 
  2.  
  3. SELECT * FROM pw_gbook WHERE id>1275480 and uid='48' ORDER BY postdate DESC LIMIT 20; 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲欧美日韩在线高清直播| 91精品国产高清自在线| 欧美老女人性生活| 亚洲黄页视频免费观看| 中文字幕亚洲激情| 亚洲精品不卡在线| 久久九九全国免费精品观看| 中文字幕亚洲一区| 国产黑人绿帽在线第一区| 日韩禁在线播放| 成人黄色生活片| 久久久极品av| 免费不卡欧美自拍视频| 色狠狠久久aa北条麻妃| 一区二区亚洲精品国产| 国产一区二区香蕉| 国产亚洲美女久久| 岛国av午夜精品| 国产亚洲一区二区精品| 久久久在线观看| 亚洲午夜精品久久久久久性色| 国产一区二区三区在线观看网站| 欧美一区在线直播| 精品偷拍一区二区三区在线看| 日韩在线不卡视频| 成人免费观看a| 第一福利永久视频精品| 国产精品88a∨| 欧美日韩免费看| 国产精品久久一| 久久人人看视频| 亚洲新声在线观看| 久久国产精品网站| 久久久久久久一| 欧美日韩国产丝袜美女| 欧美精品第一页在线播放| 久久成人精品电影| 亚洲加勒比久久88色综合| 久久精品视频播放| 懂色av中文一区二区三区天美| 亚洲欧美日韩视频一区| 国产www精品| 亚洲国产精品久久久久秋霞不卡| 成人精品久久久| 成人免费淫片视频软件| 成人精品网站在线观看| 欧美丰满少妇xxxxx做受| 日韩精品视频在线| 国产专区精品视频| 国产91精品最新在线播放| 亚洲精品电影网站| 久久精品人人爽| 亚洲国产高清福利视频| 美女性感视频久久久| 欧美激情极品视频| 91色琪琪电影亚洲精品久久| 亚洲福利视频二区| 精品视频在线播放| 亚洲男人7777| 国产98色在线| 亚洲人成网7777777国产| 国产精品久久久久77777| 欧洲亚洲在线视频| 欧美放荡办公室videos4k| 欧美日本在线视频中文字字幕| 国产精品永久在线| 国产精彩精品视频| 一区三区二区视频| 成人激情电影一区二区| 亚洲精品黄网在线观看| 91精品国产91久久久久久最新| 性色av一区二区三区在线观看| 成人av电影天堂| 国产女精品视频网站免费| 成人免费黄色网| 日韩在线观看电影| 91亚洲永久免费精品| 国产一区二区三区在线| 精品成人69xx.xyz| 国产视频欧美视频| 亚洲国产精品免费| 国产精品日日摸夜夜添夜夜av| 国产精品久久久久久亚洲调教| 国产成人自拍视频在线观看| 久久久久久久色| 精品久久久久久久久中文字幕| 久久久久在线观看| 国产精品一区二区久久| 久久九九有精品国产23| 国产精品免费福利| 国产成人综合亚洲| 亚洲最大成人网色| 国产一区二区黑人欧美xxxx| 日韩美女激情视频| 国产免费一区二区三区在线观看| 国产99视频精品免视看7| 亚洲人成电影在线播放| 深夜成人在线观看| 国产成人av在线播放| 精品亚洲一区二区三区在线观看| 欧美日韩一区二区在线| 亚洲韩国日本中文字幕| 中文字幕最新精品| 亚洲国产精品久久久久| 中文字幕精品在线| 超碰精品一区二区三区乱码| 成人免费视频网址| 久久久999精品视频| 欧美激情视频一区二区三区不卡| 97**国产露脸精品国产| 亚洲国内精品视频| 97久久久久久| 亚洲大尺度美女在线| 国产亚洲精品美女久久久| 日韩成人高清在线| 日韩欧美国产骚| 欧美日本高清视频| 成人国产精品一区二区| 青青久久aⅴ北条麻妃| 亚洲qvod图片区电影| 亚洲国产天堂久久综合网| 国产精品久久久久999| 国产视频亚洲精品| 国产成人精品av在线| 成人激情视频小说免费下载| 国产精品一区二区三区免费视频| 亚洲护士老师的毛茸茸最新章节| 日韩av片电影专区| 欧美午夜性色大片在线观看| 在线播放日韩av| 国语自产精品视频在免费| 欧美中文在线视频| 亚洲一区亚洲二区| 在线观看国产精品淫| 国产精品免费久久久| 国产免费亚洲高清| 精品久久久精品| 亚洲黄色免费三级| 欧美国产激情18| 成人黄色免费在线观看| 国产福利视频一区二区| 午夜精品一区二区三区视频免费看| 亚洲国产精品嫩草影院久久| 一本大道亚洲视频| 久久久久久久久久久久久久久久久久av| 最近2019中文字幕第三页视频| 日韩国产一区三区| 91亚洲精品一区二区| 亚洲片在线资源| 欧美午夜精品伦理| 69**夜色精品国产69乱| 久热99视频在线观看| 2023亚洲男人天堂| 77777少妇光屁股久久一区| 亚洲xxx大片| 国产欧美一区二区三区视频| 一区二区三区视频在线| 久久免费观看视频| 少妇精69xxtheporn| 亚洲аv电影天堂网| 国产精品一区二区久久久久| 欧美韩国理论所午夜片917电影| 亚洲人成在线观看| 欧美性xxxx极品高清hd直播|