java-SSH2实现数据库和界面的分页

 更新时间:2016年10月20日 11:43:03   作者:liuchangqing123  
本文主要是介绍SSH2实现数据库和界面的分页的代码,分页在web应用中是经常要做的事情,实用性比较大,有需要的朋友可以来了解一下。

分页应该是在我们开发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可以继续关注本站。

相关文章

  • 实现java简单的线程池

    实现java简单的线程池

    这篇文章主要为大家详细介绍了java简单实现多线程,及java爬虫使用线程池实例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07
  • 详解mybatis-plus配置找不到Mapper接口路径的坑

    详解mybatis-plus配置找不到Mapper接口路径的坑

    这篇文章主要介绍了详解mybatis-plus配置找不到Mapper接口路径的坑,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-10-10
  • SpringBoot集成EasyExcel的应用场景分析

    SpringBoot集成EasyExcel的应用场景分析

    这篇文章主要介绍了SpringBoot集成EasyExcel的应用场景,java领域解析、生成excel比较有名的框架有apache poi、jxl等,今天通过实例代码给大家详细介绍,需要的朋友可以参考下
    2021-07-07
  • Java中自动生成构造方法详解

    Java中自动生成构造方法详解

    这篇文章主要介绍了Java中自动生成构造方法详解的相关资料,需要的朋友可以参考下
    2017-04-04
  • Spring boot2.0 日志集成方法分享(1)

    Spring boot2.0 日志集成方法分享(1)

    这篇文章主要介绍了Spring boot2.0 日志集成方法分享,Spring Boot使用Apache的Commons Logging作为内部的日志框架,其仅仅是一个日志接口,在实际应用中需要为该接口来指定相应的日志实现,下文日志实现详情需要的小伙伴可以参考一下
    2022-04-04
  • Spring 整合Shiro 并扩展使用EL表达式的实例详解

    Spring 整合Shiro 并扩展使用EL表达式的实例详解

    Shiro是一个轻量级的权限控制框架,应用非常广泛。本文的重点是介绍Spring整合Shiro,并通过扩展使用Spring的EL表达式。需要的朋友可以参考下
    2018-03-03
  • Java之单例设计模式示例详解

    Java之单例设计模式示例详解

    这篇文章主要介绍了Java之单例设计模式示例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • java灵活使用mysql中json类型字段存储数据详解

    java灵活使用mysql中json类型字段存储数据详解

    在数据库设计中,面对一对多的关系,如订单和商品,可以考虑使用单表存储而非传统的分表方式,这篇文章主要介绍了java灵活使用mysql中json类型字段存储数据的相关资料,需要的朋友可以参考下
    2024-09-09
  • 浅谈Spring事务传播行为实战

    浅谈Spring事务传播行为实战

    这篇文章主要介绍了浅谈Spring事务传播行为实战,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-09-09
  • java 汉诺塔Hanoi递归、非递归(仿系统递归)和非递归规律 实现代码

    java 汉诺塔Hanoi递归、非递归(仿系统递归)和非递归规律 实现代码

    汉诺塔(Hanoi) 算法Java实现。通过三个函数,分别对Hanoi进行递归、非递归和非递归规律实现。
    2013-05-05

最新评论