Java分頁(yè)查詢--分頁(yè)顯示(實(shí)例講解)
當(dāng)數(shù)據(jù)庫(kù)中數(shù)據(jù)條數(shù)過多時(shí),一個(gè)頁(yè)面就不能顯示,這是要設(shè)置分頁(yè)查詢,首先要使用的是數(shù)據(jù)庫(kù)sql語(yǔ)句的limit條件實(shí)現(xiàn)分組查詢
sql語(yǔ)句大概形式為:
select * from table limit 開始索引,顯示條數(shù)
用該語(yǔ)句就會(huì)實(shí)現(xiàn)分塊查詢,并且每頁(yè)顯示固定條數(shù)。
首先要實(shí)現(xiàn)后臺(tái)分頁(yè),我們需要知道它有多少頁(yè),每頁(yè)有多少行,這就需要知道一共多少行,調(diào)用sql語(yǔ)句時(shí)還需要知道每一頁(yè)的開始索引,開始索引是根據(jù)當(dāng)前頁(yè)數(shù)算出來的,所以還需要知道當(dāng)前頁(yè)數(shù),查詢后會(huì)返回一個(gè)列表存儲(chǔ)當(dāng)前頁(yè)數(shù)據(jù)。將這些屬性及獲取設(shè)置的方法封裝成一個(gè)類就有了下面的page類:
Page類
public class Page<T> { private List<T> data;//數(shù)據(jù)列表 private int pagenum;//當(dāng)前頁(yè)數(shù) private int pagesize;//當(dāng)前頁(yè)顯示條數(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ì)算總頁(yè)數(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ù),頁(yè)數(shù)及每頁(yè)顯示條數(shù)。數(shù)據(jù)總條數(shù)可以用sql語(yǔ)句select count(*)from table 獲得。每次查詢時(shí)只需要傳入當(dāng)前頁(yè)數(shù)就可以了。將每次查詢后的page對(duì)象傳入jsp前臺(tái)頁(yè)面,并以一個(gè)div來顯示
顯示div
<div> <a href="/stuent8.11/stuServlet?pagenum=1" rel="external nofollow" >首頁(yè)</a> <a href="/stuent8.11/stuServlet?pagenum=${apage.pagenum-1 }" rel="external nofollow" >上一頁(yè)</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" >下一頁(yè)</a> <a href="/stuent8.11/stuServlet?pagenum=${apage.totalpage }" rel="external nofollow" >末頁(yè)</a> </div>
其中的一個(gè)choose是用于規(guī)定頁(yè)面顯示的最大頁(yè)數(shù),這里是5頁(yè),就是說當(dāng)點(diǎn)到第4頁(yè)是時(shí),第1頁(yè)就會(huì)消失,出現(xiàn)第6頁(yè)。
以上這篇Java分頁(yè)查詢--分頁(yè)顯示(實(shí)例講解)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Spring Web項(xiàng)目spring配置文件隨服務(wù)器啟動(dòng)時(shí)自動(dòng)加載
這篇文章主要介紹了Spring Web項(xiàng)目spring配置文件隨服務(wù)器啟動(dòng)時(shí)自動(dòng)加載,加載spring的配置文件,并且只加載一次,從而提高程序效率。具體內(nèi)容詳情大家通過本文一起學(xué)習(xí)吧2018-01-01Java實(shí)現(xiàn)動(dòng)態(tài)驗(yàn)證碼生成
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)動(dòng)態(tài)驗(yàn)證碼生成,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04mybatis-plus-boot-starter包與mybatis-plus-generator的沖突解決
本文主要介紹了mybatis-plus-boot-starter包與mybatis-plus-generator的沖突解決,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-10-10java中線程的sleep()方法和yield()方法的區(qū)別
本文主要介紹了java中線程的sleep()方法和yield()方法的區(qū)別,Thread類的sleep()方法使線程休眠指定時(shí)間,不釋放鎖,而yield()提示調(diào)度器當(dāng)前線程愿意讓出CPU資源,不保證立即切換線程,感興趣的可以了解一下2024-10-10