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.l配置检查
# 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⽅法之后,多⽤了⼀次查询⽤户部门信息,导致了分页参数失效。
mysql操作官方文档查看pageHelper官⽹⽂档之后,证实了⾃⼰的想法,官⽅⽂档截图如下:
3、问题解决
那既然不能在pageHelper的startpage⽅法之后使⽤,那就在分页之前先查⼀波,这样就不会破坏它定
义的使⽤规则了,后来事实证明,这种⽅法是可⾏的。
测试结果如下:

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。