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

官方文档:pagehelper
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);
   }
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Spring Boot项目使用MyBatis进行分页查询,你可以按照以下步骤进行操作: 1. 首先,确保你的Spring Boot项目已经引入了MyBatis的相关依赖。可以在你的pom.xml文件添加以下依赖: ```xml <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>latest_version</version> </dependency> ``` 2. 创建一个Mapper接口,用于定义分页查询的方法。例如: ```java import org.apache.ibatis.annotations.Mapper; import java.util.List; @Mapper public interface UserMapper { List<User> getUsersByPage(int offset, int limit); } ``` 3. 在对应的Mapper XML文件编写SQL语句,使用数据库的分页功能。例如,使用MySQL的LIMIT语句来实现分页查询: ```xml <select id="getUsersByPage" resultType="User"> SELECT * FROM user LIMIT #{offset}, #{limit} </select> ``` 其,`offset`表示查询的起始位置,`limit`表示每页返回的记录数。 4. 在Service层或者Controller层调用Mapper接口的方法进行分页查询。可以使用PageHelper或者手动计算分页参数。 使用PageHelper插件的示例代码如下: ```java import com.github.pagehelper.PageHelper; import com.github.pagehelper.PageInfo; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import java.util.List; @Service public class UserService { @Autowired private UserMapper userMapper; public List<User> getUsersByPage(int pageNum, int pageSize) { PageHelper.startPage(pageNum, pageSize); List<User> userList = userMapper.getUsersByPage(); PageInfo<User> pageInfo = new PageInfo<>(userList); return pageInfo.getList(); } } ``` 手动计算分页参数的示例代码如下: ```java import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import java.util.List; @Service public class UserService { @Autowired private UserMapper userMapper; public List<User> getUsersByPage(int pageNum, int pageSize) { int offset = (pageNum - 1) * pageSize; return userMapper.getUsersByPage(offset, pageSize); } } ``` 这样就可以在Spring Boot项目使用MyBatis进行分页查询了。 希望对你有所帮助!如果还有其他问题,请继续提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值