分頁應該是在我們開發web應用時經常要做的工作,能夠比較簡潔的實現數據庫和視圖層的分頁十分重要。在數據庫層利用Hibernate進行數據庫的分頁,將從數據庫中查詢出的數據封裝爲javabean;在視圖層就可以方便的實現分頁。
創建PageBean
package com.fishing.common.bean;
import java.util.List;
@SuppressWarnings("unchecked")
publicclass PageBean {
private List list; // 要返回的某一頁的記錄列表
privateint allRow; // 總記錄數
privateint totalPage; // 總頁數
privateint currentPage; // 當前頁
privateint pageSize; // 每頁記錄數
privateboolean isFirstPage; // 是否爲第一頁
privateboolean isLastPage; // 是否爲最後一頁
privateboolean hasPreviousPage; // 是否有前一頁
privateboolean hasNextPage; // 是否有下一頁
public List getList() {
return list;
}
publicvoid setList(List list) {
this.list = list;
}
publicint getAllRow() {
return allRow;
}
publicvoid setAllRow(int allRow) {
this.allRow = allRow;
}
publicint getTotalPage() {
return totalPage;
}
publicvoid setTotalPage(int totalPage) {
this.totalPage = totalPage;
}
publicint getCurrentPage() {
return currentPage;
}
publicvoid setCurrentPage(int currentPage) {
this.currentPage = currentPage;
}
publicint getPageSize() {
return pageSize;
}
publicvoid setPageSize(int pageSize) {
this.pageSize = pageSize;
}
/** */
/**
* 初始化分頁信息
*/
publicvoid init() {
this.isFirstPage = isFirstPage();
this.isLastPage = isLastPage();
this.hasPreviousPage = isHasPreviousPage();
this.hasNextPage = isHasNextPage();
}
/** */
/**
* 以下判斷頁的信息,只需getter方法(is方法)即可
*
* @return
*/
publicboolean isFirstPage() {
return (currentPage == 1);// 如是當前頁是第1頁
}
publicboolean isLastPage() {
return currentPage == totalPage; //如果當前頁是最後一頁
}
publicboolean isHasPreviousPage() {
return currentPage != 1; //只要當前頁不是第1頁
}
publicboolean isHasNextPage() {
return currentPage != totalPage; //只要當前頁不是最後1頁
}
/** */
/**
* 計算總頁數,靜態方法,供外部直接通過類名調用
*
* @param pageSize
* 每頁記錄數
* @param allRow
* 總記錄數
* @return 總頁數
*/
publicstaticint countTotalPage(finalint pageSize, finalint allRow) {
int totalPage = allRow % pageSize == 0 ? allRow / pageSize : allRow
/ pageSize + 1;
return totalPage;
}
/** */
/**
* 計算當前頁開始記錄
*
* @param pageSize
* 每頁記錄數
* @param currentPage
* 當前第幾頁
* @return 當前頁開始記錄號
*/
publicstaticint countOffset(finalint pageSize, finalint currentPage) {
finalint offset = pageSize * (currentPage - 1);
return offset;
}
/** */
/**
* 計算當前頁,若爲0或者請求的URL中沒有"?page=",則用1代替
*
* @param page
* 傳入的參數(可能爲空,即0,則返回1)
* @return 當前頁
*/
publicstaticint countCurrentPage(int page) {
finalint curPage = (page == 0 ? 1 : page);
return curPage;
}
}
在Dao的抽象接口BaseDao中添加方法
public List queryForPage(final String hql, finalint offset,
finalint length);
在Dao的實現類JianSheDWDaoImpl中實現方法
public List queryForPage(final String hql, finalint offset,
finalint length) {
List list = getHibernateTemplate().executeFind(new HibernateCallback() {
public Object doInHibernate(Session session)
throws HibernateException, SQLException {
Query query = session.createQuery(hql);
query.setFirstResult(offset);
query.setMaxResults(length);
List list = query.list();
return list;
}
});
return list;
}
在service抽象層接口JianSheDWService中添加方法
public PageBean queryForPage(int pageSize,int currentPage);
在service實現類中實現方法
public PageBean queryForPage(int pageSize, int page) {
final String hql = "from JianSheDWBean"; // 查詢語句
int allRow = this.baseDao.getAllRowCount(hql); // 總記錄數
int totalPage = PageBean.countTotalPage(pageSize, allRow); // 總頁數
finalint offset = PageBean.countOffset(pageSize, page); // 當前頁開始記錄
finalint length = pageSize; // 每頁記錄數
finalint currentPage = PageBean.countCurrentPage(page);
List<JianSheDWBean> list = this.baseDao.queryForPage(hql, offset, length); // "一頁"的記錄
// 把分頁信息保存到Bean中
PageBean pageBean = new PageBean();
pageBean.setPageSize(pageSize);
pageBean.setCurrentPage(currentPage);
pageBean.setAllRow(allRow);
pageBean.setTotalPage(totalPage);
pageBean.setList(list);
pageBean.init();
return pageBean;
}
在視圖層action中建立分頁模型
package com.fishing.action.lcq;
import com.fishing.common.bean.JianSheDWBean;
import com.fishing.common.bean.PageBean;
import com.fishing.service.lcq.JianSheDWService;
import com.opensymphony.xwork2.ActionSupport;
@SuppressWarnings("serial")
publicclass GetInfoJSDWListAction extends ActionSupport {
privateint page; // 第幾頁
private PageBean pageBean; // 包含分佈信息的bean
private JianSheDWBean jianSheDWBean;
// private PageBean page;
private JianSheDWService jianSheDWService;
publicint getPage() {
return page;
}
publicvoid setPage(int page) {
this.page = page;
}
public PageBean getPageBean() {
return pageBean;
}
publicvoid setPageBean(PageBean pageBean) {
this.pageBean = pageBean;
}
public JianSheDWBean getJianSheDWBean() {
return jianSheDWBean;
}
publicvoid setJianSheDWBean(JianSheDWBean jianSheDWBean) {
this.jianSheDWBean = jianSheDWBean;
}
public JianSheDWService getJianSheDWService() {
return jianSheDWService;
}
publicvoid setJianSheDWService(JianSheDWService jianSheDWService) {
this.jianSheDWService = jianSheDWService;
}
@Override
public String execute() throws Exception {
//分頁的pageBean,參數pageSize表示每頁顯示記錄數,page爲當前頁
this.pageBean = jianSheDWService.queryForPage(10, page);
return SUCCESS;
}
}
上面只是代碼的實現,沒有說明配置文件的配置,讀者根據情況配置。