SpringBoot 全家桶 | MyBatisPlus(四)分页与排序

MyBatisPlus有现成的分页功能,需要将插件添加到配置中

配置分页插件

@Configuration
public class MybatisPlusConfig {


    /**
     * 新的分页插件,一缓和二缓遵循mybatis的规则
     *
     * @return
     */
    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
        return interceptor;
    }
}

分页查询并排序

@Test
public void testSelectPage() {
    Page<User> page = new Page<>(3, 3);
    page.addOrder(OrderItem.asc("age"));
    Page<User> userPage = userMapper.selectPage(page, null);
    System.out.println("总条数:" + userPage.getTotal());
    System.out.println("当前页数:" + userPage.getCurrent());
    System.out.println("每页大小:" + userPage.getSize());
    System.out.println("当页大小:" + userPage.getRecords().size());
    System.out.println(userPage.getRecords());
}

执行日志:

JDBC Connection [HikariProxyConnection@1347294617 wrapping com.mysql.cj.jdbc.ConnectionImpl@71f96dfb] will not be managed by Spring
==>  Preparing: SELECT COUNT(1) FROM user
==> Parameters: 
<==    Columns: COUNT(1)
<==        Row: 8
<==      Total: 1
==>  Preparing: SELECT id, name, age, email FROM user ORDER BY age ASC LIMIT ?,?
==> Parameters: 6(Long), 3(Long)
<==    Columns: id, name, age, email
<==        Row: 4, Sandy, 21, test4@baomidou.com
<==        Row: 3, Tom, 28, test3@baomidou.com
<==      Total: 2
Closing non transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@cb0f763]
总条数:8
当前页数:3
每页大小:3
当页大小:2
[User{id=4, name='Sandy', age=21, email='test4@baomidou.com'}, User{id=3, name='Tom', age=28, email='test3@baomidou.com'}]

通过日志可以看出,

  • 通过SELECT COUNT(1) FROM user查询出总页数
  • 并先排序再通过limit分页查询

上一篇:SpringBoot 全家桶 | MyBatisPlus(三)条件构造器
下一篇:SpringBoot 全家桶 | MyBatisPlus(五)主键生成策略

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
在Spring Boot项目中使用Mybatis Plus实现分页查询,需要以下几个步骤: 1. 引入Mybatis Plus和Mybatis Plus分页插件的依赖: ```xml <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.4.0</version> </dependency> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-extension</artifactId> <version>3.4.0</version> </dependency> ``` 2. 在Mybatis Plus的配置文件中配置分页插件: ```java @Configuration public class MybatisPlusConfig { @Bean public PaginationInterceptor paginationInterceptor() { return new PaginationInterceptor(); } } ``` 3. 在Mapper接口中定义分页查询方法,并使用Mybatis Plus的分页参数对象Page: ```java public interface UserMapper extends BaseMapper<User> { IPage<User> selectPageVo(Page<?> page); } ``` 4. 在Service层中调用分页查询方法: ```java @Service public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService { @Override public IPage<User> selectPageVo(Page<?> page) { return baseMapper.selectPageVo(page); } } ``` 5. 在Controller层中接收前端传来的分页参数,调用Service层的分页查询方法,并将查询结果返回给前端: ```java @RestController public class UserController { @Autowired private UserService userService; @GetMapping("/users") public IPage<User> selectPageVo(@RequestParam(defaultValue = "1") Integer pageNum, @RequestParam(defaultValue = "10") Integer pageSize) { Page<User> page = new Page<>(pageNum, pageSize); return userService.selectPageVo(page); } } ``` 以上就是在Spring Boot项目中使用Mybatis Plus实现分页查询的步骤。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

码农StayUp

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

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

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

打赏作者

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

抵扣说明:

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

余额充值