热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

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

本文主要是介绍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 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中编写分页

 
                           
                              
                           
                           
                               
                           首页   上一页 
                           
                             
                              首页 
                              " />上一页 
 
                             
                           
                           
                             
 
                              ">下一页 
                              ">尾页 
                               
                             
                              
                           下一页 尾页  
                           
                           
 
                           
                            
页次 / 记录

 上面只是代码的实现,没有说明配置文件的配置,读者根据情况配置。

希望本文所述对你有所帮助,SSH2实现数据库和界面的分页内容就给大家介绍到这里了。希望大家继续关注我们的网站!想要学习java可以继续关注本站。


推荐阅读
  • Java学习笔记之使用反射+泛型构建通用DAO
    本文介绍了使用反射和泛型构建通用DAO的方法,通过减少代码冗余度来提高开发效率。通过示例说明了如何使用反射和泛型来实现对不同表的相同操作,从而避免重复编写相似的代码。该方法可以在Java学习中起到较大的帮助作用。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • Centos7.6安装Gitlab教程及注意事项
    本文介绍了在Centos7.6系统下安装Gitlab的详细教程,并提供了一些注意事项。教程包括查看系统版本、安装必要的软件包、配置防火墙等步骤。同时,还强调了使用阿里云服务器时的特殊配置需求,以及建议至少4GB的可用RAM来运行GitLab。 ... [详细]
  • eclipse学习(第三章:ssh中的Hibernate)——11.Hibernate的缓存(2级缓存,get和load)
    本文介绍了eclipse学习中的第三章内容,主要讲解了ssh中的Hibernate的缓存,包括2级缓存和get方法、load方法的区别。文章还涉及了项目实践和相关知识点的讲解。 ... [详细]
  • HDFS2.x新特性
    一、集群间数据拷贝scp实现两个远程主机之间的文件复制scp-rhello.txtroothadoop103:useratguiguhello.txt推pushscp-rr ... [详细]
  • 如何在服务器主机上实现文件共享的方法和工具
    本文介绍了在服务器主机上实现文件共享的方法和工具,包括Linux主机和Windows主机的文件传输方式,Web运维和FTP/SFTP客户端运维两种方式,以及使用WinSCP工具将文件上传至Linux云服务器的操作方法。此外,还介绍了在迁移过程中需要安装迁移Agent并输入目的端服务器所在华为云的AK/SK,以及主机迁移服务会收集的源端服务器信息。 ... [详细]
  • 如何在文本中运行Java程序
    本文介绍了在文本中运行Java程序的步骤,包括创建文本文档、修改后缀、打开DOS命令窗口、编译和运行程序。通过这些步骤,可以在文本中成功运行Java程序并输出结果。 ... [详细]
  • 海马s5近光灯能否直接更换为H7?
    本文主要介绍了海马s5车型的近光灯是否可以直接更换为H7灯泡,并提供了完整的教程下载地址。此外,还详细讲解了DSP功能函数中的数据拷贝、数据填充和浮点数转换为定点数的相关内容。 ... [详细]
  • React项目中运用React技巧解决实际问题的总结
    本文总结了在React项目中如何运用React技巧解决一些实际问题,包括取消请求和页面卸载的关联,利用useEffect和AbortController等技术实现请求的取消。文章中的代码是简化后的例子,但思想是相通的。 ... [详细]
  • iOS Swift中如何实现自动登录?
    本文介绍了在iOS Swift中如何实现自动登录的方法,包括使用故事板、SWRevealViewController等技术,以及解决用户注销后重新登录自动跳转到主页的问题。 ... [详细]
  • 本文介绍了使用SSH免密登录的步骤,包括生成公私钥、传递公钥给被登录机、修改文件权限的操作。同时提醒用户注意私钥的传递方式,建议使用U盘等离线方式传递。 ... [详细]
  • 原理:dismiss再弹出,把dialog设为全局对象。if(dialog!null&&dialog.isShowing()&&!(Activity.)isFinishing()) ... [详细]
  • SpringBoot整合SpringSecurity+JWT实现单点登录
    SpringBoot整合SpringSecurity+JWT实现单点登录,Go语言社区,Golang程序员人脉社 ... [详细]
  • LVS实现负载均衡的原理LVS负载均衡负载均衡集群是LoadBalance集群。是一种将网络上的访问流量分布于各个节点,以降低服务器压力,更好的向客户端 ... [详细]
  • 本文详细介绍了在Centos7上部署安装zabbix5.0的步骤和注意事项,包括准备工作、获取所需的yum源、关闭防火墙和SELINUX等。提供了一步一步的操作指南,帮助读者顺利完成安装过程。 ... [详细]
author-avatar
手机用户2602883205_410
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有