亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

java分頁工具類的使用方法

 更新時間:2018年03月24日 15:35:19   作者:攻城魚  
這篇文章主要為大家詳細介紹了java分頁工具類的使用方法,穩(wěn)定的分頁效果,包括導航頁碼功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下

說明:曾經(jīng)在網(wǎng)上看過花樣繁多的分頁,很多都號稱如何通用,但很多時候往往不盡如人意:有在分頁類中還加入URL地址信息的,有在分頁類中還進行分頁動作處理(此動作完全屬于操作數(shù)據(jù)庫方面的事情)的。現(xiàn)在好了,經(jīng)本人總結(jié)與提煉:

無論你是否自己手動分頁,還是借助了框架進行分頁。此工具類都可以幫助你達到穩(wěn)定的分頁效果(包括導航頁碼功能),而且使用方法也相對簡單:好了,廢話少說,代碼如下:

package test.dao; 
 
import java.util.List; 
 
/** 
 * 用于分頁的工具類 
 * @author 莫取網(wǎng)名 
 */ 
public class Pager<T> { 
 
 private List<T> list; //對象記錄結(jié)果集 
 private int total = 0; // 總記錄數(shù) 
 private int limit = 20; // 每頁顯示記錄數(shù) 
 private int pages = 1; // 總頁數(shù) 
 private int pageNumber = 1; // 當前頁 
  
 private boolean isFirstPage=false;  //是否為第一頁 
 private boolean isLastPage=false;   //是否為最后一頁 
 private boolean hasPreviousPage=false; //是否有前一頁 
 private boolean hasNextPage=false;  //是否有下一頁 
  
 private int navigatePages=8; //導航頁碼數(shù) 
 private int[] navigatePageNumbers; //所有導航頁號 
  
 public Pager(int total, int pageNumber) { 
  init(total, pageNumber, limit); 
 } 
  
 public Pager(int total, int pageNumber, int limit) { 
  init(total, pageNumber, limit); 
 } 
  
 private void init(int total, int pageNumber, int limit){ 
  //設(shè)置基本參數(shù) 
  this.total=total; 
  this.limit=limit; 
  this.pages=(this.total-1)/this.limit+1; 
   
  //根據(jù)輸入可能錯誤的當前號碼進行自動糾正 
  if(pageNumber<1){ 
   this.pageNumber=1; 
  }else if(pageNumber>this.pages){ 
   this.pageNumber=this.pages; 
  }else{ 
   this.pageNumber=pageNumber; 
  } 
   
  //基本參數(shù)設(shè)定之后進行導航頁面的計算 
  calcNavigatePageNumbers(); 
   
  //以及頁面邊界的判定 
  judgePageBoudary(); 
 } 
  
 /** 
  * 計算導航頁 
  */ 
 private void calcNavigatePageNumbers(){ 
  //當總頁數(shù)小于或等于導航頁碼數(shù)時 
  if(pages<=navigatePages){ 
   navigatePageNumbers=new int[pages]; 
   for(int i=0;i<pages;i++){ 
    navigatePageNumbers[i]=i+1; 
   } 
  }else{ //當總頁數(shù)大于導航頁碼數(shù)時 
   navigatePageNumbers=new int[navigatePages]; 
   int startNum=pageNumber-navigatePages/2; 
   int endNum=pageNumber+navigatePages/2; 
    
   if(startNum<1){ 
    startNum=1; 
    //(最前navigatePages頁 
    for(int i=0;i<navigatePages;i++){ 
     navigatePageNumbers[i]=startNum++; 
    } 
   }else if(endNum>pages){ 
    endNum=pages; 
    //最后navigatePages頁 
    for(int i=navigatePages-1;i>=0;i--){ 
     navigatePageNumbers[i]=endNum--; 
    } 
   }else{ 
    //所有中間頁 
    for(int i=0;i<navigatePages;i++){ 
     navigatePageNumbers[i]=startNum++; 
    } 
   } 
  } 
 } 
 
 /** 
  * 判定頁面邊界 
  */ 
 private void judgePageBoudary(){ 
  isFirstPage = pageNumber == 1; 
  isLastPage = pageNumber == pages && pageNumber!=1; 
  hasPreviousPage = pageNumber > 1; 
  hasNextPage = pageNumber < pages; 
 } 
  
  
 public void setList(List<T> list) { 
  this.list = list; 
 } 
 
 /** 
  * 得到當前頁的內(nèi)容 
  * @return {List} 
  */ 
 public List<T> getList() { 
  return list; 
 } 
 
 /** 
  * 得到記錄總數(shù) 
  * @return {int} 
  */ 
 public int getTotal() { 
  return total; 
 } 
 
 /** 
  * 得到每頁顯示多少條記錄 
  * @return {int} 
  */ 
 public int getLimit() { 
  return limit; 
 } 
 
 /** 
  * 得到頁面總數(shù) 
  * @return {int} 
  */ 
 public int getPages() { 
  return pages; 
 } 
 
 /** 
  * 得到當前頁號 
  * @return {int} 
  */ 
 public int getPageNumber() { 
  return pageNumber; 
 } 
 
 
 /** 
  * 得到所有導航頁號 
  * @return {int[]} 
  */ 
 public int[] getNavigatePageNumbers() { 
  return navigatePageNumbers; 
 } 
 
 public boolean isFirstPage() { 
  return isFirstPage; 
 } 
 
 public boolean isLastPage() { 
  return isLastPage; 
 } 
 
 public boolean hasPreviousPage() { 
  return hasPreviousPage; 
 } 
 
 public boolean hasNextPage() { 
  return hasNextPage; 
 } 
 
 public String toString(){ 
  StringBuffer sb=new StringBuffer(); 
  sb.append("[") 
   .append("total=").append(total) 
   .append(",pages=").append(pages) 
   .append(",pageNumber=").append(pageNumber) 
   .append(",limit=").append(limit) 
   .append(",isFirstPage=").append(isFirstPage) 
   .append(",isLastPage=").append(isLastPage) 
   .append(",hasPreviousPage=").append(hasPreviousPage) 
   .append(",hasNextPage=").append(hasNextPage) 
  .append(",navigatePageNumbers="); 
  int len=navigatePageNumbers.length; 
  if(len>0)sb.append(navigatePageNumbers[0]); 
  for(int i=1;i<len;i++){ 
   sb.append(" "+navigatePageNumbers[i]); 
  } 
  sb.append(",list.size="+list.size()); 
  sb.append("]"); 
  return sb.toString(); 
 } 
} 

關(guān)于用法:使用步驟如下:

1).不管是否用了條件查詢,首先count出相應(yīng)的總條數(shù)
2).構(gòu)造一個Pager類(關(guān)于limit參數(shù)可根據(jù)自身前臺進行取舍)
3).根據(jù)構(gòu)造好的Pager類獲取已經(jīng)自動糾正過的pageNumber參數(shù),-1再乘個limit,做為實際要查詢的第一條記錄的位置
4).設(shè)置要查從起始位置開始,直到第limit條的所有記錄.(如果手工分頁,則也有可能第二個參數(shù)是結(jié)尾記錄的位置偏移,具體情況視數(shù)據(jù)庫而定)
5).將[條件]查詢出的list設(shè)置入pager對象中并返回.
6).在展現(xiàn)層通過Servlet或Action或直接拿到這個pager對象即可使用,具體如何拼接url的事情,也應(yīng)該交由展現(xiàn)層來完成即可。

int totalCount=Integer.valueOf(queryCount.uniqueResult().toString()); 
Pager pager=new Pager(totalCount, pageNumber,limit); 
queryList.setFirstResult((pager.getPageNumber()-1)*limit); //容錯處理 
queryList.setMaxResults(limit); 
pager.setList(queryList.list()); 
return pager; 

上述代碼是使用了hibernate的一個簡單示例。如果你是手工分頁,也按使用步驟來即可。

當然了,分頁可以放在dao層來完成,也可以放在Service層來完成。而Servlet或Action則去調(diào)用service層的代碼。個人認為:分頁其實也是一種業(yè)務(wù)需要,因此,可以將其放在業(yè)務(wù)層。因為DAO層提供相應(yīng)的[條件查詢]list及[條件]統(tǒng)計count,在業(yè)務(wù)層完全可以根據(jù)自己的需要進行方法調(diào)用(只不過需要按既定的步驟來罷了,當然了,很多時候,業(yè)務(wù)都是有既定的流程步驟的)。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • MyBatis-Plus條件構(gòu)造器Wrapper應(yīng)用實例

    MyBatis-Plus條件構(gòu)造器Wrapper應(yīng)用實例

    QueryWrapper是用于查詢的Wrapper條件構(gòu)造器,可以通過它來構(gòu)建SELECT語句中的WHERE條件,這篇文章主要介紹了MyBatis-Plus數(shù)據(jù)表操作條件構(gòu)造器Wrapper,需要的朋友可以參考下
    2023-09-09
  • 如何在Redis中實現(xiàn)分頁排序查詢過程解析

    如何在Redis中實現(xiàn)分頁排序查詢過程解析

    這篇文章主要介紹了如何在Redis中實現(xiàn)分頁排序查詢過程解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-07-07
  • 基于ComponentScan注解的掃描范圍及源碼解析

    基于ComponentScan注解的掃描范圍及源碼解析

    這篇文章主要介紹了基于ComponentScan注解的掃描范圍及源碼解析,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • MyBatis利用MyCat實現(xiàn)多租戶的簡單思路分享

    MyBatis利用MyCat實現(xiàn)多租戶的簡單思路分享

    這篇文章主要給大家介紹了關(guān)于MyBatis利用MyCat實現(xiàn)多租戶的簡單思路的相關(guān)資料,文中的多租戶是基于多數(shù)據(jù)庫進行實現(xiàn)的,數(shù)據(jù)是通過不同數(shù)據(jù)庫進行隔離,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-06-06
  • Java中new關(guān)鍵字和newInstance方法的區(qū)別分享

    Java中new關(guān)鍵字和newInstance方法的區(qū)別分享

    在初始化一個類,生成一個實例的時候,newInstance()方法和new關(guān)鍵字除了一個是方法一個是關(guān)鍵字外,最主要的區(qū)別是創(chuàng)建對象的方式不同
    2013-07-07
  • 基于sharding-jdbc的使用限制

    基于sharding-jdbc的使用限制

    這篇文章主要介紹了sharding-jdbc的使用限制,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • Java反轉(zhuǎn)字符串的10種方法

    Java反轉(zhuǎn)字符串的10種方法

    這篇文章主要介紹了Java反轉(zhuǎn)字符串的10種方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,下面我們來一起學習一下吧
    2019-06-06
  • Java從同步容器到并發(fā)容器的操作過程

    Java從同步容器到并發(fā)容器的操作過程

    這篇文章主要介紹了Java從同步容器到并發(fā)容器的操作過程,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-10-10
  • SpringBoot熔斷機制之CircuitBreaker詳解

    SpringBoot熔斷機制之CircuitBreaker詳解

    這篇文章主要介紹了SpringBoot熔斷機制之CircuitBreaker詳解,SpringBoot的熔斷機制在微服務(wù)架構(gòu)中扮演著重要角色,其中CircuitBreaker是其核心機制之一,用于防止服務(wù)的異常狀態(tài)影響到整個系統(tǒng)的運作,需要的朋友可以參考下
    2023-10-10
  • Spring 加載多份配置文件的問題及解決方案

    Spring 加載多份配置文件的問題及解決方案

    在Spring項目中,有時候需要加載多份配置文件以簡化復雜的配置管理,解決這一問題的方法是使用spring.config.import屬性,通過這種方式,可以在主配置文件中指定額外的配置文件路徑,支持文件、classpath或URL形式的路徑,感興趣的朋友跟隨小編一起看看吧
    2024-10-10

最新評論