SpringBoot+MyBatis分页失效问题解决(已解决)

in 编程
关注公众号【好便宜】( ID:haopianyi222 ),领红包啦~
阿里云,国内最大的云服务商,注册就送数千元优惠券:https://t.cn/AiQe5A0g
腾讯云,良心云,价格优惠: https://t.cn/AieHwwKl
搬瓦工,CN2 GIA 优质线路,搭梯子、海外建站推荐: https://t.cn/AieHwfX9

如果你不是SpringBoot项目,Maven依赖:

 <dependency>
    <groupId>com.github.pagehelper</groupId>
    <artifactId>pagehelper</artifactId>
    <version>4.1.0</version>
</dependency>

<dependency>
    <groupId>com.github.miemiedev</groupId>
    <artifactId>mybatis-paginator</artifactId>
    <version>1.2.17</version>
</dependency>

基本配置

使用@Bean方式配置:

@Configuration
public class PageHelperConfig {

    @Bean
    public PageHelper pageHelper(){
        PageHelper pageHelper = new PageHelper();
        Properties properties = new Properties();
        properties.setProperty("helper-dialect","mysql");
        properties.setProperty("offsetAsPageNum", "true");
        properties.setProperty("rowBoundsWithCount", "true");
        properties.setProperty("reasonable", "true");

        pageHelper.setProperties(properties);
        return pageHelper;
    }
}

application.properties方式配置:

#pagehelper配置
pagehelper.helperDialect: mysql
pagehelper.reasonable: true
pagehelper.supportMethodsArguments: true
pagehelper.params: count=countSql

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

<!-- pagehelper -->
<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,但是分页就是不生效,每次都会查出全量数据,因为配置文件都配置好没有错,那肯定是代码出错,当我查看官网文档的时候,发现官网的介绍分页失效的原因:

4. 什么时候会导致不安全的分页?
PageHelper 方法使用了静态的 ThreadLocal 参数,分页参数和线程是绑定的。

只要你可以保证在 PageHelper 方法调用后紧跟 MyBatis 查询方法,这就是安全的。
因为 PageHelper 在 finally 代码段中自动清除了 ThreadLocal 存储的对象。

如果代码在进入 Executor 前发生异常,就会导致线程不可用,这属于人为的 Bug
(例如接口方法和 XML 中的不匹配,导致找不到 MappedStatement 时), 这种情况由于线程不可用,也不会导致 ThreadLocal 参数被错误的使用。
 

在看看我的业务代码:

 @Override
    public ServerResponse<PageInfo<Home>> getHomeListByFeatureIdAndDistrictCode(Long featureId, String districtCode, 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被提前消费使用了,只需要交代码改为:

 @Override
    public ServerResponse<PageInfo<Home>> getHomeListByFeatureIdAndDistrictCode(Long featureId, String districtCode, 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);
    }

这样就称解决分页失效的问题了,贴一下我的分页信息:

关注公众号【好便宜】( ID:haopianyi222 ),领红包啦~
阿里云,国内最大的云服务商,注册就送数千元优惠券:https://t.cn/AiQe5A0g
腾讯云,良心云,价格优惠: https://t.cn/AieHwwKl
搬瓦工,CN2 GIA 优质线路,搭梯子、海外建站推荐: https://t.cn/AieHwfX9
扫一扫关注公众号添加购物返利助手,领红包
Comments are closed.

推荐使用阿里云服务器

超多优惠券

服务器最低一折,一年不到100!

朕已阅去看看