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方法之后使用,那就在分页之前先查一波,这样就不会破坏它定义的使用规则了,后来事实证明,这种方法是可行的。
测试结果如下:
参考博客: