Java分頁查詢--分頁顯示(實(shí)例講解)
當(dāng)數(shù)據(jù)庫中數(shù)據(jù)條數(shù)過多時(shí),一個(gè)頁面就不能顯示,這是要設(shè)置分頁查詢,首先要使用的是數(shù)據(jù)庫sql語句的limit條件實(shí)現(xiàn)分組查詢
sql語句大概形式為:
select * from table limit 開始索引,顯示條數(shù)
用該語句就會(huì)實(shí)現(xiàn)分塊查詢,并且每頁顯示固定條數(shù)。
首先要實(shí)現(xiàn)后臺(tái)分頁,我們需要知道它有多少頁,每頁有多少行,這就需要知道一共多少行,調(diào)用sql語句時(shí)還需要知道每一頁的開始索引,開始索引是根據(jù)當(dāng)前頁數(shù)算出來的,所以還需要知道當(dāng)前頁數(shù),查詢后會(huì)返回一個(gè)列表存儲(chǔ)當(dāng)前頁數(shù)據(jù)。將這些屬性及獲取設(shè)置的方法封裝成一個(gè)類就有了下面的page類:
Page類
public class Page<T> {
private List<T> data;//數(shù)據(jù)列表
private int pagenum;//當(dāng)前頁數(shù)
private int pagesize;//當(dāng)前頁顯示條數(shù)
private int rows;//總行數(shù)
public Page(int rows,int pagenum, int pagesize) {
super();
data=new ArrayList<>();
this.rows=rows;
this.setPagesize(pagesize);
this.setPagenum(pagenum);
}
public Page() {
super();
}
public int getPagenum() {
return pagenum;
}
public void setPagenum(int pagenum) {
if(pagenum>getTotalpage())
{
this.pagenum=getTotalpage();
}
else {
this.pagenum = pagenum;
}
if(pagenum<1)
{
this.pagenum=1;
}
}
public int getPagesize() {
return pagesize;
}
public void setPagesize(int pagesize) {
this.pagesize = pagesize;
}
public int getTotalpage() {
//計(jì)算總頁數(shù)
if(rows%pagesize==0)
{
return rows/pagesize;
}
else {
return rows/pagesize+1;
}
}
public int getRows() {
return rows;
}
public void setRows(int rows) {
this.rows = rows;
}
public int getIndexnum() {
//獲取索引值
return pagesize*(pagenum-1);
}
public List<T> getData() {
return data;
}
public void setData(List<T> data) {
this.data = data;
}
}
初始化時(shí)我們只需要獲得數(shù)據(jù)總條數(shù),頁數(shù)及每頁顯示條數(shù)。數(shù)據(jù)總條數(shù)可以用sql語句select count(*)from table 獲得。每次查詢時(shí)只需要傳入當(dāng)前頁數(shù)就可以了。將每次查詢后的page對(duì)象傳入jsp前臺(tái)頁面,并以一個(gè)div來顯示
顯示div
<div>
<a href="/stuent8.11/stuServlet?pagenum=1" rel="external nofollow" >首頁</a>
<a href="/stuent8.11/stuServlet?pagenum=${apage.pagenum-1 }" rel="external nofollow" >上一頁</a>
<c:choose>
<c:when test="${apage.totalpage<=5 }">
<c:set var="begin" value="1"></c:set>
<c:set var="end" value="${apage.totalpage }"></c:set>
</c:when>
<c:when test="${apage.totalpage>5 }">
<c:set var="begin" value="1"></c:set>
<c:set var="end" value="5"></c:set>
<c:if test="${apage.pagenum>3 }">
<c:set var="begin" value="${apage.pagenum-2 }"></c:set>
<c:set var="end" value="${apage.pagenum+2 }"></c:set>
</c:if>
<c:if test="${end>apage.totalpage }">
<c:set var="begin" value="${apage.totalpage-4 }"></c:set>
<c:set var="end" value="${apage.totalpage }"></c:set>
</c:if>
</c:when>
</c:choose>
<c:forEach begin="${begin }" end="${end }" step="1" var="num">
<c:if test="${apage.pagenum==num }">
[${num }]
</c:if>
<c:if test="${apage.pagenum!=num }">
<a href="/stuent8.11/stuServlet?pagenum=${num }" rel="external nofollow" >${num }</a>
</c:if>
</c:forEach>
<a href="/stuent8.11/stuServlet?pagenum=${apage.pagenum+1 }" rel="external nofollow" >下一頁</a>
<a href="/stuent8.11/stuServlet?pagenum=${apage.totalpage }" rel="external nofollow" >末頁</a>
</div>
其中的一個(gè)choose是用于規(guī)定頁面顯示的最大頁數(shù),這里是5頁,就是說當(dāng)點(diǎn)到第4頁是時(shí),第1頁就會(huì)消失,出現(xiàn)第6頁。
以上這篇Java分頁查詢--分頁顯示(實(shí)例講解)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
MyBatis-Plus分頁時(shí)排序的實(shí)現(xiàn)方法
這篇文章主要介紹了MyBatis-Plus分頁時(shí)的排序,分頁時(shí)排序的方法,后端OrderItems排序、Wrapper排序前端指定排序,文章結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-03-03
Win10系統(tǒng)下配置Java環(huán)境變量
今天給大家?guī)淼氖顷P(guān)于Java的相關(guān)知識(shí),文章圍繞著Win10系統(tǒng)下配置Java環(huán)境變量展開,文中有非常詳細(xì)的介紹及圖文示例,需要的朋友可以參考下2021-06-06
java對(duì)于目錄下文件的單詞查找操作代碼實(shí)現(xiàn)
這篇文章主要介紹了java對(duì)于目錄下文件的單詞查找操作代碼實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11
idea?Maven?插件?docker-maven-plugin?打包docker鏡像上傳到遠(yuǎn)程倉庫的過程詳解
這篇文章主要介紹了idea Maven插件docker-maven-plugin打包docker鏡像上傳到遠(yuǎn)程倉庫,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-05-05
Spring Cloud實(shí)現(xiàn)微服務(wù)調(diào)用的負(fù)載均衡(詳解)
負(fù)載均衡就是將負(fù)載(工作任務(wù),訪問請(qǐng)求)進(jìn)行分?jǐn)偟蕉鄠€(gè)操作單元(服務(wù)器,組件)上進(jìn)行執(zhí)行,根據(jù)負(fù)載均衡發(fā)生位置的不同,一般分為服務(wù)端負(fù)載均衡和客戶端負(fù)載均衡,本文給大家介紹Spring Cloud實(shí)現(xiàn)微服務(wù)調(diào)用的負(fù)載均衡的相關(guān)知識(shí),感興趣的朋友一起看看吧2024-03-03

