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

SpringBoot整合MybatisPlus实现分页查询

mhr18 2024-10-11 12:43 30 浏览 0 评论

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<User> 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<User> page = new Page<>(2, 3, false);

总结

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


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

相关推荐

SpringBoot 各种分页查询方式详解(全网最全)

一、分页查询基础概念与原理1.1什么是分页查询分页查询是指将大量数据分割成多个小块(页)进行展示的技术,它是现代Web应用中必不可少的功能。想象一下你去图书馆找书,如果所有书都堆在一张桌子上,你很难...

《战场兄弟》全事件攻略 一般事件合同事件红装及隐藏职业攻略

《战场兄弟》全事件攻略,一般事件合同事件红装及隐藏职业攻略。《战场兄弟》事件奖励,事件条件。《战场兄弟》是OverhypeStudios制作发行的一款由xcom和桌游为灵感来源,以中世纪、低魔奇幻为...

LoadRunner(loadrunner录制不到脚本)

一、核心组件与工作流程LoadRunner性能测试工具-并发测试-正版软件下载-使用教程-价格-官方代理商的架构围绕三大核心组件构建,形成完整测试闭环:VirtualUserGenerator(...

Redis数据类型介绍(redis 数据类型)

介绍Redis支持五种数据类型:String(字符串),Hash(哈希),List(列表),Set(集合)及Zset(sortedset:有序集合)。1、字符串类型概述1.1、数据类型Redis支持...

RMAN备份监控及优化总结(rman备份原理)

今天主要介绍一下如何对RMAN备份监控及优化,这里就不讲rman备份的一些原理了,仅供参考。一、监控RMAN备份1、确定备份源与备份设备的最大速度从磁盘读的速度和磁带写的带度、备份的速度不可能超出这两...

备份软件调用rman接口备份报错RMAN-06820 ORA-17629 ORA-17627

一、报错描述:备份归档报错无法连接主库进行归档,监听问题12541RMAN-06820:WARNING:failedtoarchivecurrentlogatprimarydatab...

增量备份修复物理备库gap(增量备份恢复数据库步骤)

适用场景:主备不同步,主库归档日志已删除且无备份.解决方案:主库增量备份修复dg备库中的gap.具体步骤:1、停止同步>alterdatabaserecovermanagedstand...

一分钟看懂,如何白嫖sql工具(白嫖数据库)

如何白嫖sql工具?1分钟看懂。今天分享一个免费的sql工具,毕竟现在比较火的NavicatDbeaverDatagrip都需要付费才能使用完整功能。幸亏今天有了这款SQLynx,它不仅支持国内外...

「开源资讯」数据管理与可视化分析平台,DataGear 1.6.1 发布

前言数据齿轮(DataGear)是一款数据库管理系统,使用Java语言开发,采用浏览器/服务器架构,以数据管理为核心功能,支持多种数据库。它的数据模型并不是原始的数据库表,而是融合了数据库表及表间关系...

您还在手工打造增删改查代码么,该神器带你脱离苦海

作为Java开发程序,日常开发中,都会使用Spring框架,完成日常的功能开发;在相关业务系统中,难免存在各种增删改查的接口需求开发。通常来说,实现增删改查有如下几个方式:纯手工打造,编写各种Cont...

Linux基础知识(linux基础知识点及答案)

系统目录结构/bin:命令和应用程序。/boot:这里存放的是启动Linux时使用的一些核心文件,包括一些连接文件以及镜像文件。/dev:dev是Device(设备)的缩写,该目录...

PL/SQL 杂谈(二)(pl/sql developer使用)

承接(一)部分。我们从结构和功能这两个方面展示PL/SQL的关键要素。可以看看PL/SQL的优雅的代码。写出一个好的代码,就和文科生写出一篇优秀的作文一样,那么赏心悦目。1、与SQL的集成PL/S...

电商ERP系统哪个好用?(电商erp哪个好一点)

电商ERP系统哪个好用?做电商的,谁还没被ERP折腾过?有老板说:“我们早就上了ERP,订单、库存、财务全搞定,系统用得飞起。”也有运营吐槽:“系统是上了,可库存老不准,订单漏单错单天天有,财务对账还...

汽车检测线系统实例,看集中控制与PLC分布控制

PLC可编程控制器,上个世纪70年代初,为取代早期继电器控制线路,开始采取存储指令方式,完成顺序控制而设计的。开始仅有逻辑运算、计时、计数等简单功能。随着微处理的发展,PLC可编程能力日益提高,已经能...

苹果五件套成公司年会奖品主角,几大小技巧教你玩转苹果新品

钱江晚报·小时新闻记者张云山随着春节的临近,各家大公司的年会又将陆续上演。上周,各大游戏公司的年会大奖,苹果五件套又成了标配。在上海的游戏公司中,莉莉丝奖品列表拉得相当长,从特等奖到九等奖还包含了特...

取消回复欢迎 发表评论: