原创

SpringBoot mybatis-plus分页失效问题解决方式

SpringBoot项目,直接导入 pagehelper-spring-boot-starter

<dependency>
     <groupId>com.github.pagehelper</groupId>
     <artifactId>pagehelper-spring-boot-starter</artifactId>
     <version>1.2.5</version>
</dependency>

SpringBoot的自动配置都帮我们实现配置了可以不需要上面的配置,因为SpringBoot很多配置采用了默认机制,我是使用 pagehelper-spring-boot-starter 方式的,发现分页总是返回所有的数据total,但是分页就是不生效,每次都会查出全量数据,因为配置文件都配置好没有错,那肯定是代码出错,当我查看官网文档的时候,发现官网的介绍分页失效的原因:

什么时候会导致不安全的分页?

PageHelper 方法使用了静态的 ThreadLocal 参数,分页参数和线程是绑定的。

只要你可以保证在 PageHelper 方法调用后紧跟 MyBatis 查询方法,这就是安全的。

因为 PageHelper 在 finally 代码段中自动清除了 ThreadLocal 存储的对象。

如果代码在进入 Executor 前发生异常,就会导致线程不可用,这属于人为的 Bug

(例如接口方法和 XML 中的不匹配,导致找不到 MappedStatement 时), 这种情况由于线程不可用,也不会导致 ThreadLocal 参数被错误的使用。

错误代码:

public PageInfo<T> get88( int pageNum, int pageSize) {
PageHelper.startPage(pageNum,pageSize);
String district = areaMapper.selectAreaNameByCode(districtCode);
List<Home> homeList = homeMapper.selectAllHomeByFeatureIdDistrict(featureId, district);
PageInfo<Home> pageResult = new PageInfo<>(homeList);
return ServerResponse.createBySuccess(pageResult);
    }

看了我的代码,顿时醒悟,PageHelper.startPage(pageNum,pageSize); 后面接的方法是areaMapper.selectAreaNameByCode(); 而我需要分页的方法是下面selectAllHomeByFeatureIdDistrict()方法,所有PageHelper.startPage被提前消费使用了,只需要交代码改为:

public PageInfo<T> get88( int pageNum, int pageSize) {
       String district = areaMapper.selectAreaNameByCode(districtCode); 
       //记住:PageHelper.startPage要紧跟着要分页的方法
       PageHelper.startPage(pageNum,pageSize);
       List<Home> homeList = homeMapper.selectAllHomeByFeatureIdDistrict(featureId, district);
       PageInfo<Home> pageResult = new PageInfo<>(homeList);
       return ServerResponse.createBySuccess(pageResult);
   }
~阅读全文-人机检测~

微信公众号“Java精选”(w_z90110),专注Java技术干货分享!让你从此路人变大神!回复关键词领取资料:如Mysql、Hadoop、Dubbo、Spring Boot等,免费领取视频教程、资料文档和项目源码。微信搜索小程序“Java精选面试题”,内涵3000+道Java面试题!

涵盖:互联网那些事、算法与数据结构、SpringMVC、Spring boot、Spring Cloud、ElasticSearch、Linux、Mysql、Oracle等

评论

分享:

支付宝

微信