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可以持續存眷本站。