分页应该是在我们开发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可以继续关注本站。
本文向大家介绍asp.net实现access数据库分页的方法,包括了asp.net实现access数据库分页的方法的使用技巧和注意事项,需要的朋友参考一下 asp.net操作access数据库是常见的数据库操作应用,本文就来实例讲解一下asp.net实现access数据库分页的方法。希望对大家的asp.net程序设计能有所帮助。 具体实例代码如下: 相信本文实例能对大家的asp.net程序设计带来
本文向大家介绍C#定制Excel界面并实现与数据库交互的方法,包括了C#定制Excel界面并实现与数据库交互的方法的使用技巧和注意事项,需要的朋友参考一下 Excel是微软办公套装软件的一个重要的组成部分,它可以进行各种数据的处理、统计分析和辅助决策操作,广泛地应用于管理、统计财经、金融等众多领域。(另外,Excel还是伦敦一所会展中心的名称)。.NET可以创建Excel Add-In对Excel
本文向大家介绍Yii实现MySQL多数据库和读写分离实例分析,包括了Yii实现MySQL多数据库和读写分离实例分析的使用技巧和注意事项,需要的朋友参考一下 本文实例分析了Yii实现MySQL多数据库和读写分离的方法。分享给大家供大家参考。具体分析如下: Yii Framework是一个基于组件、用于开发大型 Web 应用的高性能 PHP 框架。Yii提供了今日Web 2.0应用开发所需要的几乎一切
本文向大家介绍Android界面数据懒加载实现代码,包括了Android界面数据懒加载实现代码的使用技巧和注意事项,需要的朋友参考一下 大家在使用手机新闻客户端的时候就会有一个发现,大多数的新闻客户端都会把新闻分类,诸如头条、娱乐、体育、科技等等,如何实现这种界面的呢?这个实现起来其实很简单,就是在一个Fragment中实现多个ViewPage的切换,再在ViewPage的上面放一个TabLayo
本文向大家介绍Spring 实现数据库读写分离的示例,包括了Spring 实现数据库读写分离的示例的使用技巧和注意事项,需要的朋友参考一下 现在大型的电子商务系统,在数据库层面大都采用读写分离技术,就是一个Master数据库,多个Slave数据库。Master库负责数据更新和实时数据查询,Slave库当然负责非实时数据查询。因为在实际的应用中,数据库都是读多写少(读取数据的频率高,更新数据的频率相
问题内容: 我想知道这里发生了什么。 有一个http处理程序的接口: 我想我了解这种实现。 根据我的理解,“计数器”类型实现了接口,因为它具有一种具有所需签名的方法。到目前为止,一切都很好。然后给出这个例子: 有人可以详细说明为什么这些功能或如何将它们组合在一起吗? 问题答案: 这个: 说任何满足接口的类型都必须有一个方法。以上将在包装内。 这会将方法放在对应于ServeHTTP的Counter类