• SpringBoot 集成分页插件pageHelper导致分页参数失效


    1、Bug复现

      postman测试时,传入当前页pageNum,每页显示条数:pageSize,两个参数之后,不管pageSize传入任何之后,接口返回值中的pageSize都是固定不变的,与传入值不一致。

    2、问题分析

    出现问题,先看配置

    2.1 pom文件检查

    <!-- pageHelper分页插件 -->
    <dependency>
        <groupId>com.github.pagehelper</groupId>
        <artifactId>pagehelper-spring-boot-starter</artifactId>
        <version>1.2.12</version>
    </dependency>

    看完之后,发现并没有什么问题。

    2.2 application.yml配置检查

    # pageHelper分页配置
    pagehelper:
      helper-dialect: mysql
      reasonable: false
      support-methods-arguments: true
      params: count=countSql

    看了一下配置,网上有博主说,是reasonable参数配置的问题。

    问题就在reasonable这个参数配置上,reasonable可以理解为是否开启自动优化默认为false,
    如果为true当查询的页码无数据时就会返回离输入的页码最近含数据的页码数据(最后一个有数据的页码数据或者第一页的数据)。
    如果设置为false当查询的页码无数据时就直接返回空了。

    但是,我看了一下当时设置的时候,就改为了 false,所以看来还不是这个问题。

    看到这里,既然不是配置的问题,只能是代码逻辑处理的问题了。

    2.3 代码逻辑检查

    下面先贴上错误代码:

     看到这里之后,才发现自己使用pageHelper的startpage方法之后,多用了一次查询用户部门信息,导致了分页参数失效。

    3、问题解决

    那既然不能在pageHelper的startpage方法之后使用,那就在分页之前先查一波,这样就不会破坏它定义的使用规则了,后来事实证明,这种方法是可行的。

     测试结果如下:

    参考博客:

    https://blog.csdn.net/qq_38217237/article/details/84892619

    https://blog.csdn.net/qq_38217237/article/details/89061751

  • 相关阅读:
    MySQL基础知识总结
    PHP常见算法
    PHP程序功能设计
    SVN配置使用及移植
    推荐一个SpringBoot + Vue + MyBatis 音乐网站项目
    累积sql常用查询语句「Oracle」
    Nginx服务器设置http/https正向代理,使用ngx_http_proxy_connect_module模块
    squid配置文件
    nginx命令
    k8s与Docker有啥关系
  • 原文地址:https://www.cnblogs.com/cndarren/p/12558234.html
Copyright © 2020-2023  润新知