分页从网上考的,好用。这个框架
/**
* 用于分页的工具类
* @author 莫取网名
*/
public class Pager {private List 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;ipages){
endNum=pages;
//最后navigatePages页
for(int i=navigatePages-1;i>=0;i--){
navigatePageNumbers[i]=endNum--;
}
}else{
//所有中间页
for(int i=0;i 1;
hasNextPage = pageNumber < pages;
}public void setList(List list) {
this.list = list;
}/**
* 得到当前页的内容
* @return {List}
*/
public List 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
后面是使用方法
我实际项目的例子
public String getComment(int id,int startindex){commentlist = new ArrayList();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;}