SpringBoot 集成分页插件pageHelper导致分页参数失效
时间:2020-03-24
本文章向大家介绍SpringBoot 集成分页插件pageHelper导致分页参数失效,主要包括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;
原文地址:https://www.cnblogs.com/cndarren/p/12558234.html
- java教程
- Java快速入门
- Java 开发环境配置
- Java基本语法
- Java 对象和类
- Java 基本数据类型
- Java 变量类型
- Java 修饰符
- Java 运算符
- Java 循环结构
- Java 分支结构
- Java Number类
- Java Character类
- Java String类
- Java StringBuffer和StringBuilder类
- Java 数组
- Java 日期时间
- Java 正则表达式
- Java 方法
- Java 流(Stream)、文件(File)和IO
- Java 异常处理
- Java 继承
- Java 重写(Override)与重载(Overload)
- Java 多态
- Java 抽象类
- Java 封装
- Java 接口
- Java 包(package)
- Java 数据结构
- Java 集合框架
- Java 泛型
- Java 序列化
- Java 网络编程
- Java 发送邮件
- Java 多线程编程
- Java Applet基础
- Java 文档注释
- 消息队列之推还是拉,RocketMQ 和 Kafka是如何做的?
- Nginx系列:root与alias指令用法的区别
- Redis系列:Linux下部署Redis 6.x 版本
- 分布式锁的封装也很有讲究呀
- PHP与SEO,应用curl及正则获取搜狗搜索相关关键词
- Kafka经典面试题,你都会吗?
- 提高单细胞分析准确度的工具之一:Self-assembling manifolds
- 一不小心肝出了4W字的Redis面试教程
- 双向LSTM-CRF模型用于序列标注
- 容器服务 TKE 上服务暴露的几种方式
- 【论文分享】ACL 2020 信息抽取任务中的新动向
- 工匠人iOS 代码规范
- 写一个通用的幂等组件,我觉得很有必要
- PC性能监测工具,您不可或缺的好帮手~~
- 特征工程之处理时间序列数据