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;
	}

  

原文地址:https://www.cnblogs.com/lemniscate317/p/5138810.html