现在基本每一个项目都有用到分页,SSM也是当前企业用到的比较频繁的框架,这里我就总结一下基于SSM的分页:

一、首先我们要准备一个分页的工具类

  1. /**
  2. * 分页
  3. */
  4. public class Page implements Serializable {
  5. private static final long serialVersionUID = -3198048449643774660L;
  6. private int pageNow = 1; // 当前页数
  7. private int pageSize = 4; // 每页显示记录的条数
  8. private int totalCount; // 总的记录条数
  9. private int totalPageCount; // 总的页数
  10. @SuppressWarnings("unused")
  11. private int startPos; // 开始位置,从0开始
  12. @SuppressWarnings("unused")
  13. private boolean hasFirst;// 是否有首页
  14. @SuppressWarnings("unused")
  15. private boolean hasPre;// 是否有前一页
  16. @SuppressWarnings("unused")
  17. private boolean hasNext;// 是否有下一页
  18. @SuppressWarnings("unused")
  19. private boolean hasLast;// 是否有最后一页
  20. /**
  21. * 通过构造函数 传入  总记录数  和  当前页
  22. * @param totalCount
  23. * @param pageNow
  24. */
  25. public Page(int totalCount, int pageNow) {
  26. this.totalCount = totalCount;
  27. this.pageNow = pageNow;
  28. }
  29. /**
  30. * 取得总页数,总页数=总记录数/总页数
  31. * @return
  32. */
  33. public int getTotalPageCount() {
  34. totalPageCount = getTotalCount() / getPageSize();
  35. return (totalCount % pageSize == 0) ? totalPageCount
  36. : totalPageCount + 1;
  37. }
  38. public void setTotalPageCount(int totalPageCount) {
  39. this.totalPageCount = totalPageCount;
  40. }
  41. public int getPageNow() {
  42. return pageNow;
  43. }
  44. public void setPageNow(int pageNow) {
  45. this.pageNow = pageNow;
  46. }
  47. public int getPageSize() {
  48. return pageSize;
  49. }
  50. public void setPageSize(int pageSize) {
  51. this.pageSize = pageSize;
  52. }
  53. public int getTotalCount() {
  54. return totalCount;
  55. }
  56. public void setTotalCount(int totalCount) {
  57. this.totalCount = totalCount;
  58. }
  59. /**
  60. * 取得选择记录的初始位置
  61. * @return
  62. */
  63. public int getStartPos() {
  64. return (pageNow - 1) * pageSize;
  65. }
  66. public void setStartPos(int startPos) {
  67. this.startPos = startPos;
  68. }
  69. /**
  70. * 是否是第一页
  71. * @return
  72. */
  73. public boolean isHasFirst() {
  74. return (pageNow == 1) ? false : true;
  75. }
  76. public void setHasFirst(boolean hasFirst) {
  77. this.hasFirst = hasFirst;
  78. }
  79. /**
  80. * 是否有首页
  81. * @return
  82. */
  83. public boolean isHasPre() {
  84. // 如果有首页就有前一页,因为有首页就不是第一页
  85. return isHasFirst() ? true : false;
  86. }
  87. public void setHasPre(boolean hasPre) {
  88. this.hasPre = hasPre;
  89. }
  90. /**
  91. * 是否有下一页
  92. * @return
  93. */
  94. public boolean isHasNext() {
  95. // 如果有尾页就有下一页,因为有尾页表明不是最后一页
  96. return isHasLast() ? true : false;
  97. }
  98. public void setHasNext(boolean hasNext) {
  99. this.hasNext = hasNext;
  100. }
  101. /**
  102. * 是否有尾页
  103. * @return
  104. */
  105. public boolean isHasLast() {
  106. // 如果不是最后一页就有尾页
  107. return (pageNow == getTotalCount()) ? false : true;
  108. }
  109. public void setHasLast(boolean hasLast) {
  110. this.hasLast = hasLast;
  111. }
  112. }

二、编写mapper.xml的SQL语句

    1. <!-- 分页SQL语句 -->
    2. <select id="selectProductsByPage" resultMap="返回值类型">
    3. select
    4. *
    5. from 表名 WHERE user_id = #{userId,jdbcType=INTEGER} limit #{startPos},#{pageSize}
    6. </select>
    7. <!-- 取得记录的总数 -->
    8. <select id="getProductsCount" resultType="long">
    9. SELECT COUNT(*) FROM 表名 WHERE user_id = #{userId,jdbcType=INTEGER}
    10. </select>

三、DAO层编写对应的方法

    1. **
    2. * 使用注解方式传入多个参数,用户产品分页,通过登录用户ID查询
    3. * @param page
    4. * @param userId
    5. * @return startPos},#{pageSize}
    6. */
    7. public List<Products> selectProductsByPage(@Param(value="startPos") Integer startPos,@Param(value="pageSize") Integer pageSize,@Param(value="userId") Integer userId);
    8. /**
    9. * 取得产品数量信息,通过登录用户ID查询
    10. * @param userId
    11. * @return
    12. */
    13. public long getProductsCount(@Param(value="userId") Integer userId);

四、service接口

    1. /**
    2. * 分页显示商品
    3. * @param request
    4. * @param model
    5. * @param loginUserId
    6. */
    7. void showProductsByPage(HttpServletRequest request,Model model,int loginUserId);

五、service实现类

  1. @Override
  2. public void showProductsByPage(HttpServletRequest request, Model model,int loginUserId) {
  3. String pageNow = request.getParameter("pageNow");
  4. Page page = null;
  5. List<ProductWithBLOBs> products = new ArrayList<ProductWithBLOBs>();
  6. int totalCount = (int) productDao.getProductsCount(loginUserId);
  7. if (pageNow != null) {
  8. page = new Page(totalCount, Integer.parseInt(pageNow));
  9. allProducts = this.productDao.selectProductsByPage(page.getStartPos(), page.getPageSize(), loginUserId);
  10. } else {
  11. page = new Page(totalCount, 1);
  12. allProducts = this.productDao.selectProductsByPage(page.getStartPos(), page.getPageSize(), loginUserId);
  13. }
  14. model.addAttribute("products", products);
  15. model.addAttribute("page", page);
  16. }

六、controller层

  1. /**
  2. * 初始化 “我的产品”列表 JSP页面,具有分页功能
  3. *
  4. * @param request
  5. * @param model
  6. * @return
  7. */
  8. @RequestMapping(value = "映射路径", method = RequestMethod.GET)
  9. public String showMyProduct(HttpServletRequest request, Model model) {
  10. // 取得SESSION中的loginUser
  11. User loginUser = (User) request.getSession().getAttribute("loginUser");
  12. // 判断SESSION是否失效
  13. if (loginUser == null || "".equals(loginUser)) {
  14. return "redirect:/";
  15. }
  16. int loginUserId = loginUser.getUserId();
  17. //此处的productService是注入的IProductService接口的对象
  18. this.productService.showProductsByPage(request, model, loginUserId);
  19. return "跳转到的JSP路径";
  20. }

基于SSM的分页的更多相关文章

  1. Java基于ssm框架的restful应用开发

    Java基于ssm框架的restful应用开发 好几年都没写过java的应用了,这里记录下使用java ssm框架.jwt如何进行rest应用开发,文中会涉及到全局异常拦截处理.jwt校验.token ...

  2. 基于SSM的健身房管理系统

    基于SSM的健身房管理系统 The project was made in 2020-05-05~2020-05-10 谨以此片博文记录下我的第一个Java小Demo 项目展示 用户登录页 用户注册页 ...

  3. 基于SSM的租赁管理系统0.1_20161225_项目需求

    基于SSM的汽车租赁系统项目计划书 1.产品定位 本系统供提供租赁服务的企业内部使用,供企业员工进行线下操作. 2.需求分析 2.1 能为工作人员提供员工信息的管理功能,具有RBAC基于角色的权限管理 ...

  4. 基于Angularjs实现分页

    前言 学习任何一门语言前肯定是有业务需求来驱动你去学习它,当然ng也不例外,在学习ng前我第一个想做的demo就是基于ng实现分页,除去基本的计算思路外就是使用指令封装成一个插件,在需要分页的列表页面 ...

  5. 基于SSM实现的简易员工管理系统

    之前自学完了JAVA基础,一直以来也没有做什么好玩的项目,最近暑假,时间上比较空闲,所以又学习了一下最近在企业实际应用中比较流行的SSM框架,以此为基础,通过网络课程,学习编写了一个基于SSM实现的M ...

  6. 基于SSM之Mybatis接口实现增删改查(CRUD)功能

    国庆已过,要安心的学习了. SSM框架以前做过基本的了解,相比于ssh它更为优秀. 现基于JAVA应用程序用Mybatis接口简单的实现CRUD功能: 基本结构: (PS:其实这个就是用的Mapper ...

  7. 基于ArcGISServer进行分页矢量查询的方案进阶

    文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/ 1.    背景 在空间查询中,我们对查询结果要求以分页形式进行展示.G ...

  8. 基于SSM的Java Web应用开发原理初探

    SSM开发Web的框架已经很成熟了,成熟得以至于有点落后了.虽然如今是SOA架构大行其道,微服务铺天盖地的时代,不过因为仍有大量的企业开发依赖于SSM,本文简单对基于SSM的Java开发做一快速入门, ...

  9. 基于SSM框架配置多数据源

    项目基于ssm + maven,通过注解可以实现自动切换数据源. 一.pom.xml <?xml version="1.0" encoding="UTF-8&quo ...

随机推荐

  1. NOI 题库 7218

    7218  献给阿尔吉侬的花束 描述 阿尔吉侬是一只聪明又慵懒的小白鼠,它最擅长的就是走各种各样的迷宫.今天它要挑战一个非常大的迷宫,研究员们为了鼓励阿尔吉侬尽快到达终点,就在终点放了一块阿尔吉侬最喜 ...

  2. 用maven配置springboot+freemarker

    1.创建项目 直接点下一步   原因: 不勾选 Create from archetype,是项目创建的骨架的时候,由于不知道什么原因就卡住了,一直在刷新 2.创建之后完成之后 添加依赖 <pa ...

  3. (转)完全用GNU/Linux工作 by 王珢

    完全用GNU/Linux工作 王珢      (看完这篇博文,非常喜欢王珢的这篇博客,也我坚定了学gnu/linux的决心,并努力去按照国外的计算机思维模式去学习编程提高自己.看完这篇文章令我热血沸腾 ...

  4. Coreseek 安装指南

    Coreseek 中文官网:http://www.coreseek.cn/ Sphinx0.9.9 中文手册:http://www.coreseek.cn/docs/coreseek_3.2-sphi ...

  5. O(n)求1-n的逆元

    转自:http://www.2cto.com/kf/201401/272375.html 新学的一个求逆元的方法: inv[i] = ( MOD - MOD / i ) * inv[MOD%i] % ...

  6. HTML 5 视频(video)

    video 元素支持三种视频格式 IE Firefox Opera Chrome Safari 带有 Theora 视频编码和 Vorbis 音频编码的 Ogg 文件 No 3.5+ 10.5+ 5. ...

  7. EF Code First之困扰

    Code First自动更新数据库有几种方法 Code First什么都不做 Database.SetInitializer<ShopContext>(null); 发布网站的话一般要在A ...

  8. 【iCore3 双核心板_FPGA】实验二十八:基于SDRAM 的VGA 驱动器的设计

    本实验设计的VGA显示驱动完全基于FPGA实现,用SDRAM做缓存设备,通过ARM控制VGA显示的内容.ARM 通过FSMC总线向FPGA发送数据,由于总线的速度和VGA的显示速度与SDRAM的读写速 ...

  9. hihoCoder 1183 连通性一·割边与割点(Tarjan求割点与割边)

    #1183 : 连通性一·割边与割点 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 还记得上次小Hi和小Ho学校被黑客攻击的事情么,那一次攻击最后造成了学校网络数据的丢 ...

  10. soui中,列表控件动态高度的使用注意

    1.listview的模板template中,需要增加defHeight属性,即默认高度,同时,不能出现itemHeight属性,否则动态高度会失效 2.数据适配器中,重写getViewDesired ...