现在基本每一个项目都有用到分页,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. spring的Scheduled(定时任务)和多线程

    一.前言 在我们日常的开发中,经常用到数据同步的更新,这时我们采用的是spring的定时任务和java的多线程进行数据的更新,进行时实的服务调用. 二.实现思路            1.创建线程类 ...

  2. poj2689Prime Distance 素数测试

    朴素素数测试是O(x1/2)的,每一个数都测试下来就炸了 然而如果全部预处理的话才是做大死,时间空间各种炸(大约有1亿个数) 所以怎么平衡一下呢? 其实在预处理的时候可以只处理一半:把21474836 ...

  3. webform 简单控件

    html中12个表单元素添加runat="server"后称为控件 Lable 编译之后是 <span></span> 属性:CssClass  编译成 c ...

  4. WPF整理-XAML构建后台类对象

    1.XAML 接触WPF的第一眼就是XAML---XAML是用来描绘界面的.其实不然! "Actually, XAML has nothing to do with UI. It's mer ...

  5. 八月25日认识java

    java的起源:1991年SUN公司启动的“Green”项目制作出的Star7, java的发展:于1995年5月23日正NSU式发布第一个java开发工具:java在1998年推出JDK1.2,表示 ...

  6. FastJson和AsyncHttpCLient

    Android的展示数据,除了上章所讲的本地存储外,大部分数据都来自于网络.首先介绍一下Android APP开发常见的网络操作方式.从网络层面上有底层的tcp/ip,也就是我们常见的socket套接 ...

  7. Linux下安装搭建WordPress网站

    WordPress简介 WordPress 是一种使用 PHP语言和 MySQL数据库开发的开源.免费的Blog(博客,网志)引擎,用户可以在支持 PHP 和 MySQL 数据库的服务器上建立自己的 ...

  8. Java Basic - Generics

    什么是类型擦除? 类型擦除指的是通过类型参数合并,将泛型类型实例关联到同一份字节码上.编译器只为泛型类型生成一份字节码,并将其实例关联到这份字节码上.类型擦除的关键在于从泛型类型中清除类型参数的相关信 ...

  9. poj3740

    #include<stdio.h>#include<iostream>int map[16][300];int vistx[16];int visty[300];int zhe ...

  10. Spring @Autowired注解在utils静态工具类

    [转] 使用场景:在一个静态方法中,如何使用以下注入: @Autowired private ItemMapper itemMapper; @Component public class TestUt ...