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