基于SSM的分页

时间:2023-03-09 13:43:09
基于SSM的分页

现在基本每一个项目都有用到分页,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. }