java通用分頁(SSH2框架下)和基於Hibernate的BaseDao接口

一、分頁部分

1、DAO層接口的設計,在MemberDao接口中定義瞭如下兩個方法:



public interface MemberDao{
  
  //省略了其他的代碼
  
  /** *//**
   * 分頁查詢
   * @param hql 查詢的條件
   * @param offset 開始記錄
   * @param length 一次查詢幾條記錄
   * @return
   */
  public List queryForPage(final String hql,final int offset,final int length);
  
  /** *//**
   * 查詢所有記錄數
   * @param hql 查詢的條件
   * @return 總記錄數
   */
  public int getAllRowCount(String hql);
  
}


2、DAO層實現類MemberDaoImpl對上面兩個方法的實現如下:


public class MemberDaoImpl extends HibernateDaoSupport implements MemberDao {
    //省略了其他的代碼  
  
  /** *//**
   * 分頁查詢
   * @param hql 查詢的條件
   * @param offset 開始記錄
   * @param length 一次查詢幾條記錄
   * @return
   */
  public List queryForPage(final String hql,final int offset,final int 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;
  }
  
  
  /** *//**
   * 查詢所有記錄數
   * @return 總記錄數
   */
  public long getAllRowCount(String hql){
    return (Long) this.getHibernateTemplate().executeFind(new HibernateCallback() {
@Override
public Object doInHibernate(Session session) throws HibernateException, SQLException {
Query query = session.createQuery(hql);
for (int i = 0; i < values.length; i++) {
query.setParameter(i, values[i]);
}
return query.list();
}
}).get(0);
  }
  
}




3、下面我們來新建一個保存分頁信息的類PageBean,具體代碼如下:


public class PageBean {
  
  private List list;    //要返回的某一頁的記錄列表
  
  private int allRow;     //總記錄數
  private int totalPage;    //總頁數
  private int currentPage;  //當前頁
  private int pageSize;    //每頁記錄數
  
  private boolean isFirstPage;  //是否爲第一頁
  private boolean isLastPage;    //是否爲最後一頁
  private boolean hasPreviousPage;  //是否有前一頁
  private boolean hasNextPage;    //是否有下一頁
  
  
  public List getList() {
    return list;
  }
  public void setList(List list) {
    this.list = list;
  }
  public int getAllRow() {
    return allRow;
  }
  public void setAllRow(int allRow) {
    this.allRow = allRow;
  }
  public int getTotalPage() {
    return totalPage;
  }
  public void setTotalPage(int totalPage) {
    this.totalPage = totalPage;
  }
  public int getCurrentPage() {
    return currentPage;
  }
  public void setCurrentPage(int currentPage) {
    this.currentPage = currentPage;
  }
  public int getPageSize() {
    return pageSize;
  }
  public void setPageSize(int pageSize) {
    this.pageSize = pageSize;
  }
  
  /** *//**
   * 初始化分頁信息
   */
  public void init(){
    this.isFirstPage = isFirstPage();
    this.isLastPage = isLastPage();
    this.hasPreviousPage = isHasPreviousPage();
    this.hasNextPage = isHasNextPage();
  }
  
  /** *//**
   * 以下判斷頁的信息,只需getter方法(is方法)即可
   * @return
   */
  
  public boolean isFirstPage() {
    return currentPage == 1;  // 如是當前頁是第1頁
  }
  public boolean isLastPage() {
    return currentPage == totalPage;  //如果當前頁是最後一頁
  }
  public boolean isHasPreviousPage() {
    return currentPage != 1;    //只要當前頁不是第1頁
  }
  public boolean isHasNextPage() {
    return currentPage != totalPage;  //只要當前頁不是最後1頁
  }
  
  
  /** *//**
   * 計算總頁數,靜態方法,供外部直接通過類名調用
   * @param pageSize 每頁記錄數
   * @param allRow 總記錄數
   * @return 總頁數
   */
  public static int countTotalPage(final int pageSize,final int allRow){
    int totalPage = allRow % pageSize == 0 ? allRow/pageSize : allRow/pageSize+1;
    return totalPage;
  }
  
  /** *//**
   * 計算當前頁開始記錄
   * @param pageSize 每頁記錄數
   * @param currentPage 當前第幾頁
   * @return 當前頁開始記錄號
   */
  public static int countOffset(final int pageSize,final int currentPage){
    final int offset = pageSize*(currentPage-1);
    return offset;
  }
  
  /** *//**
   * 計算當前頁,若爲0或者請求的URL中沒有"?page=",則用1代替
   * @param page 傳入的參數(可能爲空,即0,則返回1)
   * @return 當前頁
   */
  public static int countCurrentPage(int page){
    final int curPage = (page==0?1:page);
    return curPage;
  }
}






4、Service層接口的設計:
public interface MemberService {
  //省略其他的代碼
  
  /** *//**
   * 分頁查詢
   * @param currentPage 當前第幾頁
   * @param pageSize 每頁大小
   * @return 封閉了分頁信息(包括記錄集list)的Bean
   */
  public PageBean queryForPage(int pageSize,int currentPage);
  
}






5、Service層實現類的部分內碼如下:


public class MemberServiceImpl implements MemberService {
 
 //通過applicationContext.xml配置文件注入MemberDao的值
  private MemberDao memberDao;
  public void setMemberDao(MemberDao memberDao) {
    this.memberDao = memberDao;
  }
  
  /** *//**
   * 分頁查詢
   * @param currentPage 當前第幾頁
   * @param pageSize 每頁大小
   * @return 封閉了分頁信息(包括記錄集list)的Bean
   */
  public PageBean queryForPage(int pageSize,int page){
  
    final String hql = "from Member";    //查詢語句
    int allRow = (int)memberDao.getAllRowCount("select count(*) " + hql);  //總記錄數
    int totalPage = PageBean.countTotalPage(pageSize, allRow);  //總頁數
    final int offset = PageBean.countOffset(pageSize, page);  //當前頁開始記錄
    final int length = pageSize;  //每頁記錄數
    final int currentPage = PageBean.countCurrentPage(page);
    List<Member> list = memberDao.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;
  }






6、在Struts2中調用queryForPageMemberService層的queryForPage()方法即可return一個包含分頁信息、符合條件的結果集list, 代碼如下:


public class ListMember extends ActionSupport{
  //通過applicationContext.xml配置文件注入memberService的值
  private MemberService memberService;
  public void setMemberService(MemberService memberService) {
    this.memberService = memberService;
  }
  
  private int page;  //第幾頁
  
  private PageBean pageBean;  //包含分佈信息的bean
  
  public int getPage() {
    return page;
  }
  
  public void setPage(int page) {    //若URL中無此參數,會默認爲第1頁
    this.page = page;
  }
  
  public PageBean getPageBean() {
    return pageBean;
  }
  
  public void setPageBean(PageBean pageBean) {
    this.pageBean = pageBean;
  }
  
  @Override
  public String execute() throws Exception {
    //分頁的pageBean,參數pageSize表示每頁顯示記錄數,page爲當前頁
    this.pageBean = memberService.queryForPage(2, page);
    return SUCCESS;
  }

}


二、BaseDao接口(基於Hibernate)

[java] view plaincopy在CODE上查看代碼片派生到我的代碼片
  1. /** 
  2.  * 基於hibernate的BaseDao接口說明: 
  3.  * 1.兩個update方法,一個通過hql語句和參數列表更新表,適合於一次更新多條記錄。另一個以實體對象爲參數,適合更新單條記錄。 
  4.  * 2.兩個find方法,一個通過hql語句和參數列表查詢實體,適合於一次查詢多條記錄。另一個通過主鍵和類類型查詢實體,返回一個實體。 
  5.  * 3.save方法保存一條記錄。 
  6.  * 4.delete方法適合每次刪除一條記錄。如果一次刪除多條記錄可以通過hql語句的update方法進行。 
  7.  * @author LWZ 
  8.  */  
  9. public interface IBaseDao<T> {  
  10.     public long update(String hql,Object...params);  
  11.     public void update(T t);  
  12.     public List<T> find(String hql,Object...params);  
  13.     public T find(Serializable serialize,Class<T> clazz);  
  14.     public long save(T t);  
  15.     public void delete(T t);  
  16. }  
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章