hibernate分页
生活随笔
收集整理的這篇文章主要介紹了
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
總結
以上是生活随笔為你收集整理的hibernate分页的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: lol30级账号多少钱,无段位的
- 下一篇: Matlab并行编程方法1