解决Mybatis-Plus或PageHelper多表分页查询总条数不对问题

在Mybatis-Plus 3.4版本后,分页查询进行了优化,但当涉及多表关联查询时,可能出现查询总数不准确的问题。分析发现,由于优化使得总条数查询仅针对主表,导致与实际查询数据的表数量不一致。解决办法是在分页查询时关闭优化,通过设置`setOptimizeCountSql(false)`,确保两次查询的SQL一致,从而修复问题。

Mybatis-Plus版本3.4之后,对分页查询进行了优化

对于单表查询是没有问题的。而需要多表关联查询(自写sql)时,就会查询调用Mybatis-Plus的

.page(E page, Wrapper queryWrapper);

方法是就就会出现查询总数不对问题。

业务需要查询的数据

我这边业务比较复杂,是做项目的时候发现的问题,(本人比较懒)没有重新写demo。所以就不要太关注业务逻辑。只要知道符合条件的数据是69条。
在这里插入图片描述

分析

正常使用分页查询时的代码
在这里插入图片描述

运行的查询sql后台日志打印情况
在这里插入图片描述

可以看到Mybatis-Plus框架分页查询时,使用了两次查询,先查询总条数,再查询数据。而做了优化就是给第一个查询进行了优化(只查主表符合查询条件的总条数),这就导致两条查询sql的表数量不一致,从而导致查询总条数不一致的情况。搞清楚了原因,那就好解决了。

解决方式:关闭优化

代码调整(关闭分页查询优化)

Page<Object> toPage = (Page<Object>) pageQuery.toPage();
toPage.setOptimizeCountSql(false);

在这里插入图片描述
运行的查询sql后台日志打印情况
在这里插入图片描述
可以看到两次查询sql是一致的。解决问题。拜了个拜

评论 3
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

你不懂、、、

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

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

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

打赏作者

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

抵扣说明:

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

余额充值