百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

SpringBoot整合MybatisPlus实现分页查询

moboyou 2025-04-11 16:14 24 浏览

SpringBoot 集成 MybatisPlus 系列

SpringBoot 版本:2.6.4
MybatisPlus 版本:3.5.1

  • SpringBoot整合MybatisPlus
  • SpringBoot整合MybatisPlus数据自动填充
  • SpringBoot整合MybatisPlus实现逻辑删除
  • SpringBoot整合MybatisPlus实现分页查询
  • SpringBoot整合MybatisPlus支持枚举类型
  • 未完待续…

分页查询是持久化框架的基础功能,Mybatis 本身也提供了分页查询,但是 Mybatis 提供的是逻辑分页,也就是先查出所有,然后在内存中进行分布,这明显不符合生产需要。所以使用 Mybatis 时通常需要自行实现拦截器,或者使用 PageHelper 之类的框架实现物理分页。

MybatisPlua 作为 MybatisPlus 版本,当然提供了物理分页功能。

准备工作

使用 MySql 数据库,设计一张 user 表,结构如下

id

name

age

email

1

Jone

18

Jone@baomidou.com

2

Jack

20

Jack@baomidou.com

3

Tom

28

Tom@baomidou.com

4

Sandy

21

Sandy@baomidou.com

5

Billie

24

Billie@baomidou.com

数据库脚本

CREATE TABLE user (
    id BIGINT(20) NOT NULL COMMENT '主键',
    name VARCHAR(32) NOT NULL COMMENT '姓名',
    age SMALLINT(4) NOT NULL DEFAULT '0' COMMENT '年龄',
    email VARCHAR(50) NOT NULL DEFAULT '' COMMENT '邮箱',
    PRIMARY KEY (id)
)

数据脚本

INSERT INTO user (id, name, age, email) VALUES
(1, 'Jone', 18, 'Jone@baomidou.com'),
(2, 'Jack', 20, 'Jack@baomidou.com'),
(3, 'Tom', 28, 'Tom@baomidou.com'),
(4, 'Sandy', 21, 'Sandy@baomidou.com'),
(5, 'Billie', 24, 'Billie@baomidou.com');

整合 MybatisPlus 实现分页查询

MybatisPlus 提供了分页插件,只需要声明一下就可以实现物理分页

@Configuration
public class GetanJdbcAutoConfiguration {

    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
        PaginationInnerInterceptor paginationInterceptor = new PaginationInnerInterceptor();
        paginationInterceptor.setDbType(DbType.MYSQL);

        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        interceptor.addInnerInterceptor(paginationInterceptor);
        return interceptor;
    }
}

分页插件有四个属性:

属性名

类型

默认值

描述

overflow

boolean

false

溢出总页数后是否进行处理(默认不处理)

maxLimit

Long


单页分页条数限制(默认无限制)

dbType

DbType


数据库类型(根据类型获取应使用的分页方言)

dialect

IDialect


方言实现类

支持的数据库

mysql、oracle、db2、h2、hsql、sqlite、postgresql、sqlserver、Phoenix、Gauss、clickhouse、Sybase、OceanBase、Firebird、cubrid、goldilocks、csiidb

测试

编写测试用例

@RunWith(SpringRunner.class)
@SpringBootTest(classes = Application.class)
public class MybatisPlusTest {

    @Autowired
    private UserMapper userMapper;

    @Test
    public void testPagination() {
        // 查询第 2 页,每页 3 条记录
        Page page = new Page<>(2, 3);
        page = userRepository.selectPage(page, null);
    }
}

查看日志,可以看到执行了以下两个语句

SELECT COUNT(*) AS total FROM user
SELECT id,name,age,email FROM user LIMIT ?,?

如果只想查询列表,不需要统计总条数,可以使用 Page 构造方法的第三个参数进行设置

Page page = new Page<>(2, 3, false);

总结

PageMybatisPlus 默认实现的分页类,也可以自己实现分页类,只需要实现 IPage 接口就可以使用分页的功能。


最后关注一下,共同学习!

相关推荐

电子EI会议!投稿进度查

今天为大家推荐一个高性价比的电子类EI会议——IEEE电子与通信工程国际会议(ICECE2024)会议号:IEEE#62199截稿时间:2024年3月25日召开时间与地点:2024年8月15...

最“稳重”的滤波算法-中位值滤波算法的思想原理及C代码实现

在信号处理和图像处理领域,滤波算法是一类用于去除噪声、平滑信号或提取特定特征的关键技术。中位值滤波算法是一种常用的非线性滤波方法,它通过取一组数据的中位值来有效减小噪声,保留信号的有用特征,所以是最稳...

实际工程项目中是怎么用卡尔曼滤波的?

就是直接使用呀!个人认为,卡尔曼滤波有三个个关键点,一个是测量,一个是预测,一个是加权测量:通过传感器,获取传感器数据即可!预测:基于模型来进行数据预测;那么问题来了,如何建模?有难有易。加权:主要就...

我拿导弹公式算桃花,结果把自己炸成了烟花

第一章:学术圈混成“顶流”,全靠学生们把我写成段子最近总有人问我:“老师,您研究导弹飞行轨迹二十年,咋还顺带研究起月老红绳的抛物线了?”我扶了扶眼镜,深沉答道:“同志,导弹和爱情的本质都是动力学问题—...

如何更好地理解神经网络的正向传播?我们需要从「矩阵乘法」入手

图:pixabay原文来源:medium作者:MattRoss「机器人圈」编译:嗯~阿童木呀、多啦A亮介绍我为什么要写这篇文章呢?主要是因为我在构建神经网络的过程中遇到了一个令人沮丧的bug,最终迫...

电力系统EI会议·权威期刊推荐!

高录用率EI会议推荐:ICPSG2025(会议号:CFP25J66-PWR)截稿时间:2025年3月15日召开时间与地点:2025年8月18-20日·新加坡论文集上线:会后3个月内提交至S...

EI论文写作全流程指南

推荐期刊《AppliedEnergy》是新能源领域权威EI/SCI双检索期刊,专注能源创新技术应用。刊号:ISSN0306-2619|CN11-2107/TK影响因子:11.2(最新数...

JMSE投稿遇坑 实验结果被推翻

期刊基础信息刊号:ISSN2077-1312全称:JournalofMarineScienceandEngineering影响因子:3.7(最新JCR数据)分区:中科院3区JCRQ2(...

斩获国际特等奖!兰理工数学建模团队为百年校庆献礼

近日,2019年美国大学生数学建模竞赛(MCM-ICM)成绩正式公布。兰州理工大学数学建模团队再创佳绩,分别获得国际特等奖(OutstandingWinner)1项、一等奖(Meritorious...

省气象台开展人员大培训岗位大练兵学习活动

5月9日,省气象台组织开展首次基于Matlab编程语言的数值模式解释应用培训,为促进研究性业务发展,积极开展“人员大培训、岗位大练兵”学习活动起到了积极作用。此次培训基于实际业务需求,着眼高原天气特色...

嵌入式软件培训

培训效果:通过系统性的培训学习,理论与实践相结合,可以胜任相关方向的开发工作。承诺:七大块专业培训,可以任意选择其中感兴趣的内容进行针对性地学习,每期培训2个月,当期没学会,可免费学习一期。本培训内容...

轧机支承辊用重载中低速圆柱滚子轴承滚子修形探讨

摘 要:探讨了轧机支承辊用重载中低速圆柱滚子轴承滚子修形的理论和方法,确定关键自变量。使用Romax软件在特定载荷工况条件下对轴承进行数值模拟分析,确定关键量的取值范围。关键词:轧机;圆柱滚子轴承;滚...

数学建模EI刊,如何避雷?

---权威EI会议推荐会议名称:国际应用数学与工程建模大会(ICAMEM)截稿时间:2025年4月20日召开时间/地点:2025年8月15日-17日·新加坡论文集上线:会后2个月内由Sp...

制造工艺误差,三维共轭齿面怎样影响,双圆弧驱动的性能?

文/扶苏秘史编辑/扶苏秘史在现代工程领域,高效、精确的传动系统对于机械装置的性能和可靠性至关重要,谐波传动作为一种创新的机械传动方式,以其独特的特性在精密机械领域引起了广泛关注。在谐波传动的进一步优化...

测绘EI会议——超详细解析

【推荐会议】会议名称:国际测绘与地理信息工程大会(ICGGE)会议编号:71035截稿时间:2025年3月20日召开时间/地点:2025年8月15-17日·德国慕尼黑论文集上线:会后2个...