MyBatis-Plus 中IPage的分页查询

为什么用 IPage?

IPageMyBatis-Plus 定义的一个接口,它不仅仅包含数据列表 (records),还包含了 总记录数 (total)、当前页 (current)、每页大小 (size) 和 总页数 (pages)。

前端拿到这个 JSON 后,可以直接用来渲染分页组件(比如 ElementUI 或 AntD 的分页器)

第一步:配置分页插件(必须!)

MyBatis-Plus 默认不开启物理分页,你需要添加一个配置类来注册 PaginationInnerInterceptor 插件。

为了支持分页查询,我们需要引入 MyBatis-Plus 的核心分页接口 IPage 和分页对象 Page

新建文件 MybatisPlusConfig.java(建议放在 config 包下):

java 复制代码
package com.example.demo.config;

import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;
import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class MybatisPlusConfig {

    /**
     * 新的分页插件,一缓和二缓遵循mybatis的规则,需要设置 MybatisConfiguration#useDeprecatedExecutor = false 避免缓存出现问题
     */
    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        
        // 添加分页插件
        PaginationInnerInterceptor paginationInnerInterceptor = new PaginationInnerInterceptor(DbType.MYSQL);
        // 设置请求的页面大于最大页后操作, true调回到首页,false 继续请求  默认false
        paginationInnerInterceptor.setOverflow(false);
        // 设置最大单页限制数量,默认 500 条,-1 不受限制
        paginationInnerInterceptor.setMaxLimit(500L);
        
        interceptor.addInnerInterceptor(paginationInnerInterceptor);
        return interceptor;
    }
}

第二步:Service 层编写分页逻辑

假设你有一个 UserService,我们需要创建一个方法来返回 IPage。

定义 Service 接口 (UserService.java)

java 复制代码
package com.example.demo.service;

import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.service.IService;
import com.example.demo.entity.User;

public interface UserService extends IService<User> {
    
    /**
     * 分页查询用户
     * @param pageNum 当前页码
     * @param pageSize 每页大小
     * @return 分页结果对象 IPage<User>
     */
    IPage<User> getUserPage(int pageNum, int pageSize);
}

第三步:Controller 层接收参数并返回

在 Controller 中,我们接收前端传来的 pageNum 和 pageSize,然后调用 Service。

java 复制代码
package com.example.demo.controller;

import com.baomidou.mybatisplus.core.metadata.IPage;
import com.example.demo.entity.User;
import com.example.demo.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

@RestController
@RequestMapping("/users")
public class UserController {

    @Autowired
    private UserService userService;

    /**
     * 分页查询接口
     * GET /users/page?pageNum=1&pageSize=10
     */
    @GetMapping("/page")
    public IPage<User> getPage(
            @RequestParam(defaultValue = "1") int pageNum,
            @RequestParam(defaultValue = "10") int pageSize) {
        
        // 直接返回 IPage 对象,Spring Boot 会自动将其序列化为 JSON
        return userService.getUserPage(pageNum, pageSize);
    }
}

进阶技巧:

通常前端不希望直接拿到 MP 原始的 IPage 结构,而是希望包裹在一个统一的 Result 对象中。

你可以修改 Controller 如下:

java 复制代码
import java.util.Map;        
import java.util.HashMap;    
@GetMapping("/page")
public Map<String, Object> getPage(
        @RequestParam(defaultValue = "1") int pageNum,
        @RequestParam(defaultValue = "10") int pageSize) {
    
    IPage<User> userPage = userService.getUserPage(pageNum, pageSize);
    
    Map<String, Object> result = new HashMap<>();
    result.put("code", 200);
    result.put("message", "success");
    result.put("data", userPage.getRecords()); // 只返回数据列表
    result.put("total", userPage.getTotal());   // 返回总数供前端做分页器
    result.put("pages", userPage.getPages());   // 返回总页数
    
    return result;
}

总结:

1.必须配置 MybatisPlusInterceptor 插件。

2.使用 new Page<>(pageNum, pageSize) 创建分页对象。

3.使用 baseMapper.selectPage(page, wrapper) 执行查询。

4.IPage 包含了 records (数据), total (总数), pages (总页数) 等关键信息。

相关推荐
剑挑星河月1 小时前
98.验证二叉搜索树
java·算法·leetcode
我登哥MVP1 小时前
Spring Boot 从“会用”到“精通”:请求映射原理
java·spring boot·后端·spring·servlet·maven·intellij-idea
阿文的代码库1 小时前
干货分享|C++运算符重载知识点
java·c++·算法
码不停蹄的玄黓1 小时前
Java 实现阻塞队列
java·开发语言
SunnyDays10111 小时前
Java 实现 PDF 转 PDF/A 和 PDF/A 转 PDF(超详细教程)
java·开发语言·pdf
basketball6161 小时前
Redis基础:3. Redis 持久化(重要)
redis·bootstrap·mybatis
muddjsv1 小时前
Java语言学习路线全解析:从入门到精通的核心模块与进阶路径
java
未若君雅裁2 小时前
线程池核心参数与执行流程
java·开发语言
东方巴黎~Sunsiny2 小时前
后端已经开始使用AI代替前端开发了
java·人工智能·状态模式