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 (总页数) 等关键信息。

相关推荐
人活一口气13 小时前
Spring Boot与AIGC的完美结合:从零搭建智能内容生成平台
java·spring boot·aigc
像我这样帅的人丶你还15 小时前
Java 后端详解(三):全局异常处理与 JPA 数据库映射
java·后端
NE_STOP15 小时前
vibe Coding -- 小项目实战
java
未秃头的程序猿21 小时前
Java 26正式发布!这3个新特性,让代码量直接减半
java·后端·面试
用户2986985301421 小时前
Word 文档文本查找与替换的 Java 实现方案
java·后端
阿哉21 小时前
Nacos 服务发现源码:藏在背后的两套事件机制,90%的人只讲了一半
java
咖啡八杯1 天前
GoF设计模式——命令模式
java·设计模式·架构
AI人工智能_电脑小能手1 天前
【大白话说Java面试题 第125题】【并发篇】第25题:说说 Java 线程的中断机制
java·后端·面试
Java内核笔记1 天前
Spring Security 源码解析(六)无状态 JWT 实践:Session 共享与自定义过滤器
java·后端
荣码1 天前
LangGraph多Agent协作:3个Agent干活比1个强,但我踩了4个坑
java·python