为什么PageHelper超过最大页数后还会返回数据

本文详细介绍了在SpringBoot项目中如何配置和使用PageHelper分页插件,包括pom.xml依赖添加、application.properties配置参数说明,以及解决分页查询不合理导致的问题。通过调整配置项,可实现更精准的分页查询。

springboot应用, 加入 PageHelper

pom.xml:
<dependency>
  <groupId>com.github.pagehelper</groupId>
  <artifactId>pagehelper-spring-boot-starter</artifactId>
  <version>1.2.3</version>
  <scope>compile</scope>
</dependency>
<dependency>
  <groupId>com.github.pagehelper</groupId>
  <artifactId>pagehelper</artifactId>
  <version>5.1.4.1</version>
  <scope>compile</scope>
</dependency>
spring. application.properties
# mybatis_config
mybatis.mapper-locations=classpath*:com/vjia/device/mapper/*.xml 
mybatis.type-aliases-package=com.vjia.device.entity
pagehelper.helperDialect = mysql
pagehelper.reasonable = true
pagehelper.supportMethodsArguments = true
pagehelper.params=count=countSql
pagehelper.returnPageInfo="check"

问题:

在微服务里面中的查询功能,使用PageHelper,数据库6行数据,

pageNum=1&pageSize=10,pageNum=2&pageSize=10,pageNum=3&pageSize=10

返回的数据都为6条。

原因:

这是PageHelper 自带的 功能,叫做reasonable分页参数合理化,3.3.0以上版本可用,默认是false。

启用合理化时,如果pageNum<1会查询第一页,如果pageNum>pages会查询最后一页;

禁用合理化时,如果pageNum<1或pageNum>pages会返回空数据。

解决:

项目加入<property name="reasonable" value="false" />,

Spring Boot项目里面 application.properties加入:pagehelper.reasonable=false
 

 

PS

pagehelper.supportMethodsArguments=true的作用如下:

 

#如果启用supportMethodsArguments参数,则pageHelper可以自动拦截请求参数中的pageNum,pageSize参数
#不启用supportMethodsArguments参数,则需使用PageHelper.startPage(pageNum,pageSize)方法调用 
pagehelper.supportMethodsArguments=true

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

kubernetes-k8s

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值