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

1、Bug复现

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

SpringBoot 集成分页插件pageHelper导致分页参数失效_第1张图片

2、问题分析

出现问题,先看配置

2.1 pom文件检查


<dependency>
    <groupId>com.github.pagehelpergroupId>
    <artifactId>pagehelper-spring-boot-starterartifactId>
    <version>1.2.12version>
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 代码逻辑检查

下面先贴上错误代码:

SpringBoot 集成分页插件pageHelper导致分页参数失效_第2张图片

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

3、问题解决

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

SpringBoot 集成分页插件pageHelper导致分页参数失效_第3张图片

 测试结果如下:

SpringBoot 集成分页插件pageHelper导致分页参数失效_第4张图片

参考博客:

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

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

 

你可能感兴趣的:(SpringBoot 集成分页插件pageHelper导致分页参数失效)