zoukankan      html  css  js  c++  java
  • hibernate分页

    分页从网上考的,好用。这个框架

    /**
    * 用于分页的工具类
    * @author 莫取网名
    */
    public class Pager<T> {
    
    private List<T> list; //对象记录结果集
    private int total = 0; // 总记录数
    private int limit = 10; // 每页显示记录数
    private int pages = 1; // 总页数
    private int pageNumber = 1; // 当前页
    
    private boolean isFirstPage=false; //是否为第一页
    private boolean isLastPage=false; //是否为最后一页
    private boolean hasPreviousPage=false; //是否有前一页
    private boolean hasNextPage=false; //是否有下一页
    
    private int navigatePages=8; //导航页码数
    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){
    //设置基本参数
    this.total=total;
    this.limit=limit;
    this.pages=(this.total-1)/this.limit+1;
    
    //根据输入可能错误的当前号码进行自动纠正
    if(pageNumber<1){
    this.pageNumber=1;
    }else if(pageNumber>this.pages){
    this.pageNumber=this.pages;
    }else{
    this.pageNumber=pageNumber;
    }
    
    //基本参数设定之后进行导航页面的计算
    calcNavigatePageNumbers();
    
    //以及页面边界的判定
    judgePageBoudary();
    }
    
    /**
    * 计算导航页
    */
    private void calcNavigatePageNumbers(){
    //当总页数小于或等于导航页码数时
    if(pages<=navigatePages){
    navigatePageNumbers=new int[pages];
    for(int i=0;i<pages;i++){
    navigatePageNumbers[i]=i+1;
    }
    }else{ //当总页数大于导航页码数时
    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;
    }
    
    /**
    * 得到当前页的内容
    * @return {List}
    */
    public List<T> getList() {
    return list;
    }
    
    /**
    * 得到记录总数
    * @return {int}
    */
    public int getTotal() {
    return total;
    }
    
    /**
    * 得到每页显示多少条记录
    * @return {int}
    */
    public int getLimit() {
    return limit;
    }
    
    /**
    * 得到页面总数
    * @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();
    }
    }
    

      

    后面是使用方法

    我实际项目的例子

    public String getComment(int id,int startindex){
    		commentlist = new ArrayList<Comment>();
    		Query query = qiandaoDao.selectnotlist("select new power.model.Comment(sc.comment, sc.songid,sc.username, ai.headimg) from Songcomment sc,Accountinfo ai where sc.songid='"+id+"' and ai.username=sc.username ");
    		pager = getPager(id, startindex, query);
    		System.out.println(pager.toString());
    		commentlist = pager.getList();
    		if (commentlist.size()>0) {
    			return JSONArray.fromObject(commentlist).toString();
    		}else{
    			return null;
    		}
    		
    	}
    	
    	public Pager getPager(int id,int startindex,Query queryList){
    		int totalCount=queryList.list().size();
    		int limit = 10;
    		Pager pager=new Pager(totalCount, startindex,limit);
    		queryList.setFirstResult((pager.getPageNumber()-1)*limit); //容错处理
    		queryList.setMaxResults(limit);
    		pager.setList(queryList.list());
    		return pager;
    	}
    

      

  • 相关阅读:
    【Stage3D学习笔记续】山寨Starling(十):高效游戏设计、纹理集和ATF
    【Stage3D学习笔记续】山寨Starling(九):上下文丢失处理方法
    【Stage3D学习笔记续】山寨Starling(八):核心优化(批处理)的实现
    echarts 百度图表
    java读properties文件 乱码
    百度地图 JSAPI使用 mark 定位地址 与周边覆盖物
    jstl format date
    MultipartEntity 乱码
    log4j与commons-logging,slf4j的关系
    maven 引入 net sf jsonlib 报错 has borken path
  • 原文地址:https://www.cnblogs.com/lemniscate317/p/5138810.html
Copyright © 2011-2022 走看看