当前位置:网站首页>IPage能正常显示数据,但是total一直等于0
IPage能正常显示数据,但是total一直等于0
2022-07-05 06:51:00 【Emmmmm_1】
问题描述:代码中使用Mybatis-Plus的自动分页,getRecords()正确,但是getTotal()一直等于0
代码逻辑没问题,所以找Mybatis-Plus配置上的问题
尝试的方法:
1. 配置类上是否加了@Configuration
2. 统计的SQL被自动优化了,导致统计结果不准确--->关闭Mybatis-Plus的自动优化
Page<?> page = new Page<>(currentPage, size); // 开启分页
page.setOptimizeCountSql(false); // 关闭mybatisPlus的自动优化这样的方法效率较低,可以自己写count sql
page.setSearchCount(false);
page.setTotal(mapper.listCount(sql));参考文章: MyBatis-Plus的IPage分页total不正确问题
3. 设置数据库的类型
PaginationInnerInterceptor page = new PaginationInnerInterceptor();
page.setDbType(DbType.MYSQL);
return page;4. 检查mybatis-plus-boot-starter版本
3.4.0版本对此部分有更新,如果是旧版本升级,会出现分页失效问题,同时idea会提示PaginationInterceptor过时,新版本改用了MybatisPlusInterceptor

最终是把PaginationInnerInterceptor换成了MybatisPlusInterceptor解决
成功的代码如下:
@Configuration
public class MybatisPlusConfig {
/**
* 实现分页配置
* @return
*/
@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor() {
MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor()); // 注册乐观锁插件
interceptor.addInnerInterceptor(new PaginationInnerInterceptor()); // 分页插件
return interceptor;
}
}这部分代码来源:Page分页records有数据,但是total=0,解决办法
边栏推荐
- Rehabilitation type force deduction brush question notes D1
- 【软件测试】04 -- 软件测试与软件开发
- mysql设置触发器问题
- [Chongqing Guangdong education] National Open University 2018 autumn 0702-22t contemporary Chinese political system reference questions
- Log4qt usage of logbase in QT project
- 小米笔试真题一
- Use ffmpeg to rotate, flip up and down, and flip horizontally
- Vant Weapp SwipeCell設置多個按鈕
- ROS2——ROS2对比ROS1(二)
- The “mode“ argument must be integer. Received an instance of Object
猜你喜欢
随机推荐
Error: “MountVolume.SetUp failed for volume pvc 故障处理
Sre core system understanding
Ros2 - workspace (V)
Configuration method and configuration file of SolidWorks GB profile library
Build a microservice cluster environment locally and learn to deploy automatically
Redis-01. First meet redis
GDB code debugging
并发编程 — 如何中断/停止一个运行中的线程?
SD_CMD_RECEIVE_SHIFT_REGISTER
基于FPGA的一维卷积神经网络CNN的实现(八)激活层实现
Cloud native related technology learning
What is linting
微信小程序路由再次跳轉不觸發onload
Ros2 - Service Service (IX)
Empire help
并发编程 — 死锁排查及处理
mingling
2. Addition and management of Oracle data files
*P++, (*p) + +, * (p++) differences
Orin 安装CUDA环境









