本文目錄一覽:
- 1、求一份JavaBean中實現MySql分頁的代碼,可以傳遞參數的,方便調用,不要寫在JSP頁面裡面的
- 2、MySQL分頁的sql語言怎麼寫?
- 3、mysql分頁查詢語句怎麼寫
- 4、MySql中查詢語句實現分頁功能
求一份JavaBean中實現MySql分頁的代碼,可以傳遞參數的,方便調用,不要寫在JSP頁面裡面的
mysql有limit好像比較給力,分頁也不是很難。
public class PageInfo implements Serializable {
private static final long serialVersionUID = 1365747893051987016L;
private int pageSize = 10; // 每頁顯示10行,可自行調節
private int recordCount; // 總行數
private int pageCount; // 總頁數
private int pageId; // 當前頁
private int startIndex; // 當前頁的開始行數
private int endIndex; // 當前頁的結束行數
private List items;//當前頁數據
public PageInfo() {
}
public int getPageSize() {
return pageSize;
}
public void setPageSize(int pageSize) {
this.pageSize = pageSize;
}
public int getRecordCount() {
return recordCount;
}
public void setRecordCount(int recordCount) {
this.recordCount = recordCount;
}
public int getPageCount() {
return pageCount;
}
public void setPageCount(int pageCount) {
this.pageCount = pageCount;
}
public int getPageId() {
return pageId;
}
public void setPageId(int pageId) {
this.pageId = pageId;
}
public int getStartIndex() {
return startIndex;
}
public void setStartIndex(int startIndex) {
this.startIndex = startIndex;
}
public int getEndIndex() {
return endIndex;
}
public void setEndIndex(int endIndex) {
this.endIndex = endIndex;
}
public List getItems() {
return items;
}
public void setItems(List items) {
this.items = items;
}
}
翻頁直接對pageId(當前頁)進行加減就可以了,有當前頁開始行數,你直接
limit(startIndex-1)*pageSize,pageSize)就可以了
MySQL分頁的sql語言怎麼寫?
1、首先我們建立一個表表的數據,這個表裡有25條數據,id從1到25。(下圖是部分截圖)
2、要分頁數據,首先我們假設一頁有10條數據,我們可以用mysql的 limit關鍵字來限定返回多少條數據。並且用order by來排序數據,這裡用 id來排序。所以第一頁的sql可以如圖這樣寫。
3、執行後得到的數據如圖,就是 id從1到10的前10條數據,因為我們是按id升序來排序的。
4、上面第一頁的sql是簡化的寫法,完整的寫法如圖,得到的結果和上圖的一模一樣。代碼里 limit 0, 10 的意思是從第一條數據開始,取10條數據。(注意的是第一條數據是從0開始的)
5、那麼第二頁的數據,關鍵是要知道是從哪一條數據開始,可以用這個公式得到: (頁碼-1) * 每頁顯示多少條,即 (2-1) * 10 = 10, 所以sql語句如圖, limit 10, 10。
6、執行後,結果正確,得到id從11到20的10條數據。
7、同理第三頁數據的sql如圖,br/就是 limit 20, 10。
8、查詢的結果如圖,因為這頁只剩下5條數據了,所以只顯示5條數據。如果你有更多頁的數據,後面的數據只需要按上面的公式,得到從哪行開始,就可以寫對應的sql語句了。
mysql分頁查詢語句怎麼寫
–1.最常用的分頁
select * from content order by id desc limit 0, 10;
–limit是MySQL中特有的分頁語法,用法如下:
–舉例:
select * from tableName limit 5; –返回前5行
select * from tableName limit 0,5; –同上,返回前5行
select * from tableName limit 5,10; –返回6-15行
MySql中查詢語句實現分頁功能
pageNow代表當前頁面,第一頁。
第一部分:看一下分頁的基本原理:
對上面的mysql語句說明:limit 10000,20的意思掃描滿足條件的10020行,扔掉前面的10000行,返回最後的20行,問題就在這裡,如果是limit 100000,100,需要掃描100100行,在一個高並發的應用里,每次查詢需要掃描超過10W行,性能肯定大打折扣。文中還提到limit n性能是沒問題的,因為只掃描n行。
第二部分:根據雅虎的幾位工程師帶來了一篇Efficient Pagination Using MySQL的報告內容擴展:在文中提到一種clue的做法,給翻頁提供一些線索,比如還是SELECT * FROM message ORDER BY id DESC,按id降序分頁,每頁20條,當前是第10頁,當前頁條目id最大的是1020,最小的是1000,如果我們只提供上一頁、下一頁這樣的跳轉(不提供到第N頁的跳轉),那麼在處理上一頁的時候SQL語句可以是:
處理下一頁的時候SQL語句可以是:
不管翻多少頁,每次查詢只掃描20行。
缺點是只能提供上一頁、下一頁的鏈接形式,但是我們的產品經理非常喜歡「上一頁 1 2 3 4 5 6 7 8 9 下一頁」這樣的鏈接方式,怎麼辦呢?
如果LIMIT m,n不可避免的話,要優化效率,只有儘可能的讓m小一下,我們擴展前面的clue做法,還是SELECT * FROM message ORDER BY id DESC,按id降序分頁,每頁20條,當前是第10頁,當前頁條目id最大的是2519,最小的是2500;
當是第10頁的SQL如下:
比如要跳到第9頁,SQL語句可以這樣寫:
比如要跳到第8頁,SQL語句可以這樣寫:
原理還是一樣,記錄住當前頁id的最大值和最小值,計算跳轉頁面和當前頁相對偏移,由於頁面相近,這個偏移量不會很大,這樣的話m值相對較小,大大減少掃描的行數。其實傳統的limit m,n,相對的偏移一直是第一頁,這樣的話越翻到後面,效率越差,而上面給出的方法就沒有這樣的問題。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/295491.html