舉例詳解用Java實現(xiàn)web分頁功能的方法
分頁問題是一個非常普遍的問題,開發(fā)者幾乎都會遇到,這里不討論具體如何分頁,說明一下Web方式下分頁的原理。首先是查詢獲得一個結(jié)果集(表現(xiàn)為查詢數(shù)據(jù)庫獲得的結(jié)果),如果結(jié)果比較多我們一般都不會一下顯示所有的數(shù)據(jù),那么就會用分頁的方式來顯示某些數(shù)據(jù)(比如20條)。因為Http的無狀態(tài)性,每一次提交都是當(dāng)作一個新的請求來處理,即使是換頁,上一次的結(jié)果對下一次是沒有影響的。
這里總結(jié)三種實現(xiàn)分頁的方式,不知道還有沒有別的!
1.每次取查詢結(jié)果的所有數(shù)據(jù),然后根據(jù)頁碼顯示指定的紀(jì)錄。
2.根據(jù)頁面只取一頁數(shù)據(jù),然后顯示這一頁,這里要構(gòu)造sql語句。
3.取一定頁數(shù)的數(shù)據(jù),就是前面兩種的折中。
這里還要注意的是這些數(shù)據(jù)是放在request還是session中,這里一一討論
1.一般不會放在session中,因為會占用大量內(nèi)存,所以要放在request里面。
優(yōu)點:實現(xiàn)比較簡單,查詢速度比較快。
缺點:占用內(nèi)存多一些,網(wǎng)絡(luò)傳輸數(shù)據(jù)多。
對于數(shù)據(jù)量比較少的查詢這種方法比較合適。這里有人把數(shù)據(jù)放在session中,這樣換頁的時候就不用重新查詢,但是這樣是極其不好的,強烈建議不要這樣使用。
2.肯定不會放在session中,因為放在session中沒有意義。
優(yōu)點:占用內(nèi)存少。
缺點:比較麻煩,必須先獲得查詢結(jié)果的總數(shù),因為要知道有多少紀(jì)錄才知道有多少頁。另外要構(gòu)造分頁查詢語句,對于不同的數(shù)據(jù)庫是不一樣的。
3.這種情況是肯定放在session中了,要不然我干嗎取好幾頁呀,這樣的實現(xiàn)是為了減少數(shù)據(jù)庫查詢的次數(shù),比如我保存第1到10的紀(jì)錄,那么換頁的時候如果在1到10之間就可以直接從session獲取。如果換到11頁,我可以重新設(shè)置緩存11到
20頁的數(shù)據(jù)(或者5到15頁的數(shù)據(jù)),這樣的話換10次才需要一次數(shù)據(jù)庫查詢操作。
優(yōu)點:占用內(nèi)存相對不多,提高平均查詢速度。
缺點:實現(xiàn)起來更加復(fù)雜,可能存在臟數(shù)據(jù),需要自己定義一個緩存集合。如果查詢的數(shù)據(jù)量比較大,可以考慮采用這樣方式。
下面的設(shè)計每次只獲取一頁數(shù)據(jù),每次都要重新設(shè)置查詢總數(shù),具體如何獲得自己實現(xiàn),這是一個比較通用的分頁實現(xiàn)。
這里設(shè)計一個接口:
package treeroot.util; import java.util.List; /** * 該接口用來實現(xiàn)分頁功能,注意這里沒有提供修改的功能。 * @author treerot * @version 1.0 * @since 2004-9-30 */ public interface Pageable { /** * 獲得數(shù)據(jù)結(jié)果 * @return */ public List getResult(); /** * 獲得查詢總數(shù) * @return */ public int getCount(); /** * 獲得每頁紀(jì)錄數(shù) * @return */ public int getPageSize(); /** * 獲得當(dāng)前頁編號 * @return */ public int getCurrentPage(); /** * 獲得總頁數(shù) * @return */ public int getPages(); /** * 每頁默認(rèn)顯示紀(jì)錄數(shù) */ public final static int DEFAULT_PAGESIZE=20; }
這個接口非常簡單,就是包括一個結(jié)果列表和一些分頁的必要信息,這里注意幾點:
1.這個接口的實現(xiàn)表示的是某一次查詢的某一頁數(shù)據(jù),和上次查詢無關(guān)
2.這個接口的實現(xiàn)應(yīng)該是只讀的,也就是說不可以修改的。
3.getPages()方法是冗余的,但是這里仍然提供這個方法。
下面給出一個抽象實現(xiàn):
package treeroot.util; import java.util.List; /** * @author treerot * @version 1.0 * @since 2004-9-30 */ public abstract class AbstractPage implements Pageable { private int currentPage; private int pageSize; private int pages; protected int count; protected List result; /** * 指定當(dāng)前頁 * @param currentPage * @throws PageException */ public AbstractPage(int currentPage){ this(currentPage,Pageable.DEFAULT_PAGESIZE); } /** * 指定當(dāng)前頁和頁大小 * @param currentPage * @param pageSize * @throws PageException */ public AbstractPage(int currentPage,int pageSize) { this.currentPage=currentPage; this.pageSize=pageSize; } protected void checkPage(int currentPage) throws PageException{ if((currentPage<1)||(currentPage>this.getPages())) throw new PageException("頁超出范圍:總頁數(shù)為"+this.getPages()+",當(dāng)前頁為"+currentPage); } /** * 這個方法被子類重寫用來初始化,也就是計算count值和result結(jié)果,在子類 的構(gòu)造函數(shù)中調(diào)用。 */ abstract protected void init() throws PageException; public List getResult() { return result; } public int getCount() { return count; } public int getPageSize() { return pageSize; } public int getCurrentPage() { return currentPage; } public int getPages() { if(pages==0) this.pages=(count+pageSize-1)/pageSize; return pages; } }
這個抽象類實現(xiàn)了接口中的所有方法,但是定義了一個抽象方法init(),在子類中必須實現(xiàn)這個方法。上面的一個接口和一個抽象類看起來比較簡單,你可能會覺得好像什么都沒有做,實現(xiàn)上確實沒有做什么,但是卻可以給開發(fā)帶來很大的幫助。我們可以根據(jù)自己的需要要繼承這個抽象類,而數(shù)據(jù)可以通過各種方式獲得,比如直接通過一個List獲得,或者通過JDBC,Hibernate等等,不過我們都需要把結(jié)果封裝到一個List里面,通過Hibernate就顯得特別方便了。
PageException是自定義的一個異常
package treeroot.util /** * @author treeroot * @version 1.0 * @since 2004-9-30 */ public class PageException extends Exception { public PageException(){ super(); } public PageException(String message){ super(message); } }
相關(guān)文章
Springboot整個Quartz實現(xiàn)動態(tài)定時任務(wù)的示例代碼
這篇文章主要介紹了Springboot整個Quartz實現(xiàn)動態(tài)定時任務(wù)的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-09-09Java實現(xiàn)將CSV轉(zhuǎn)為Excel的示例代碼
CSV(Comma?Separated?Values)文件是一種純文本文件,包含用逗號分隔的數(shù)據(jù),常用于將數(shù)據(jù)從一個應(yīng)用程序?qū)牖驅(qū)С龅搅硪粋€應(yīng)用程序。本文將利用Java實現(xiàn)CSV轉(zhuǎn)為Excel,感興趣的可以了解一下2022-03-03