程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> java-SSH2完成數據庫和界面的分頁

java-SSH2完成數據庫和界面的分頁

編輯:關於JAVA

java-SSH2完成數據庫和界面的分頁。本站提示廣大學習愛好者:(java-SSH2完成數據庫和界面的分頁)文章只能為提供參考,不一定能成為您想要的結果。以下是java-SSH2完成數據庫和界面的分頁正文


分頁應當是在我們開辟web運用時常常要做的任務,可以或許比擬簡練的完成數據庫和視圖層的分頁非常主要。

在數據庫層應用hibernate停止數據庫的分頁,將從數據庫中查詢出的數據封裝為javabean;在視圖層便可以便利的完成分頁。

創立PageBean

package com.fishing.common.bean; 
 
import java.util.List; 
@SuppressWarnings("unchecked") 
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; 
  } 
} 

在Dao的籠統接口BaseDao中添加辦法:

public List queryForPage(final String hql, final int offset, 
      final int length); 
在Dao的完成類JianSheDWDaoImpl中完成辦法
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; 
  } 

在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); // 總頁數 
    final int offset = PageBean.countOffset(pageSize, page); // 以後頁開端記載 
    final int length = pageSize; // 每頁記載數 
    final int 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") 
public class GetInfoJSDWListAction extends ActionSupport { 
 
  private int page; // 第幾頁 
 
  private PageBean pageBean; // 包括散布信息的bean 
 
  private JianSheDWBean jianSheDWBean; 
  // private PageBean page; 
  private JianSheDWService jianSheDWService; 
 
  public int getPage() { 
    return page; 
  } 
 
  public void setPage(int page) { 
    this.page = page; 
  } 
 
  public PageBean getPageBean() { 
    return pageBean; 
  } 
 
  public void setPageBean(PageBean pageBean) { 
    this.pageBean = pageBean; 
  } 
 
  public JianSheDWBean getJianSheDWBean() { 
    return jianSheDWBean; 
  } 
 
  public void setJianSheDWBean(JianSheDWBean jianSheDWBean) { 
    this.jianSheDWBean = jianSheDWBean; 
  } 
 
  public JianSheDWService getJianSheDWService() { 
    return jianSheDWService; 
  } 
 
  public void setJianSheDWService(JianSheDWService jianSheDWService) { 
    this.jianSheDWService = jianSheDWService; 
  } 
 
  @Override   
   public String execute() throws Exception {   
     
   //分頁的pageBean,參數pageSize表現每頁顯示記載數,page為以後頁   
   this.pageBean = jianSheDWService.queryForPage(10, page);   
   return SUCCESS; 
  } 
} 

在jsp中編寫分頁

<tr class="odd"> 
                          <td> 
                              
                          </td> 
                          <td> 
                            <s:if test="%{pageBean.currentPage == 1}">   
                           首頁   上一頁 
                          </s:if> 
                            <s:else> 
                              <a href="jianguan/getJSDWInfos.action?page=1">首頁</a> 
                              <a 
                                href="jianguan/getJSDWInfos.action?page=<s:property value="%{pageBean.currentPage-1}"/>" />上一頁</a> 
 
                            </s:else> 
                          </td> 
                          <td> 
                            <s:if test="%{pageBean.currentPage != pageBean.totalPage}"> 
 
                              <a 
                                href="jianguan/getJSDWInfos.action?page=<s:property value="%{pageBean.currentPage+1}"/>">下一頁</a> 
                              <a 
                                href="jianguan/getJSDWInfos.action?page=<s:property value="pageBean.totalPage"/>">尾頁 
                              </a> 
                            </s:if> 
                            <s:else>  
                           下一頁 尾頁  
                          </s:else> 
                          </td> 
 
                          <td> 
                            <div align="center"> 
                              頁次 
                              <s:property value="pageBean.currentPage" /> 
                              / 
                              <s:property value="pageBean.totalPage" /> 
                                共 
                              <s:property value="pageBean.allRow" /> 
                              記載 
                            </div> 
                            <div align="center"></div> 
                          </td> 
                        </tr> 

 下面只是代碼的完成,沒有解釋設置裝備擺設文件的設置裝備擺設,讀者依據情形設置裝備擺設。

願望本文所述對你有所贊助,SSH2完成數據庫和界面的分頁內容就給年夜家引見到這裡了。願望年夜家持續存眷我們的網站!想要進修java可以持續存眷本站。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved