从MySQL基本语句的分页查询到MyBatis再到MyBatis-plus

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: # 引言在实际开发中,我们为了提高页面的响应速度,也为了优化用户的体验,同时也减少流量和性能的消耗,往往在面对大量数据时会采取分页的操作。接下来这篇文章我带大家从原生的SQL语句中的分页到MyBatis中去分页,最后我们再看一下MyBatis-plus下的分页操作。# MySQL的分页(分页在SQL层面的原理)MySQL 分页操作可以使用 `LIMIT` 和 `OFFSET` 子句来实现。例如,如果想从一个 `users` 表中选择第二页(每页显示 10 条记录)的数据,可以使用以下查询:```SELECT * FROM users LIMIT 10 OFFSET

引言

在实际开发中,我们为了提高页面的响应速度,也为了优化用户的体验,同时也减少流量和性能的消耗,往往在面对大量数据时会采取分页的操作。

接下来这篇文章我带大家从原生的SQL语句中的分页到MyBatis中去分页,最后我们再看一下MyBatis-plus下的分页操作。

MySQL的分页(分页在SQL层面的原理)

MySQL 分页操作可以使用 LIMITOFFSET 子句来实现。

例如,如果想从一个 users 表中选择第二页(每页显示 10 条记录)的数据,可以使用以下查询:

SELECT * FROM users LIMIT 10 OFFSET 10;

这将从第 11 条记录开始,选择后面的 10 条记录。

如果想选择前 10 条记录,可以使用以下查询:

SELECT * FROM users LIMIT 10;

我们还可以将 LIMITOFFSETWHERE 子句一起使用,以筛选数据。例如,如果想选择所有状态为 "active" 的用户,并从第二页开始(每页显示 10 条记录),可以使用以下查询:

SELECT * FROM users WHERE status = 'active' LIMIT 10 OFFSET 10;

MyBatis中使用分页

在 MyBatis 中使用分页,同样使用 LIMITOFFSET 子句,并通过参数传递给 SQL 语句。

例如,如果有一个名为 UserMapper 的接口和一个对应的 XML 映射文件,你可以在 XML 映射文件中定义如下分页查询:

<select id="selectUsers" resultType="com.example.User">
  SELECT * FROM users
  WHERE status = #{status}
  LIMIT #{limit} OFFSET #{offset}
</select>

然后,我们可以在 UserMapper 接口中使用以下方法调用分页查询:

List<User> selectUsers(@Param("status") String status, @Param("offset") int offset, @Param("limit") int limit);

我们也可以可以通过调用该方法来选择状态为 "active" 的用户,并从第二页开始(每页显示 10 条记录)

List<User> users = userMapper.selectUsers("active", 10, 10);

mybatis-plus如何分页呢

Mybatis Plus 是一个 Mybatis 的增强工具,可以简化 Mybatis 的使用,并提供一些额外的功能。

在 Mybatis Plus 中使用分页,你需要使用 com.baomidou.mybatisplus.extension.plugins.pagination.Page 类。 该类是一个分页信息对象,包含了当前页码、每页大小等信息。

值得一提的是,MyBatis-plus是对MyBatis的一个升级,一个增强,一个扩展,引入他到你的项目中并不会对之前的MyBatis有什么影响,你可以很丝滑的在项目中去使用他。

例如,如果你想查询第二页(每页显示 10 条记录)的用户数据,可以使用以下代码:

Page<User> page = new Page<>(2, 10);
List<User> users = userMapper.selectPage(page, null);

其中,第一个参数是 Page 对象,第二个参数是查询条件。

然后,你可以使用 page.getTotal() 方法获取总记录数,page.getRecords() 方法获取当前页的数据列表。

注意,在 Mybatis Plus 中,你需要在对应的 XML 映射文件中启用分页插件,才能使用分页功能。例如:


<!-- 在mapper节点上启用分页插件 -->
<mapper namespace="com.example.UserMapper">
  <plugin interceptor="com.baomidou.mybatisplus.extension.plugins.PaginationInterceptor"/>
</mapper>

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
3月前
|
SQL Java 数据库连接
mybatis如何实现分页查询?
【10月更文挑战第19天】mybatis如何实现分页查询?
169 3
|
3月前
|
Java 关系型数据库 MySQL
springboot学习五:springboot整合Mybatis 连接 mysql数据库
这篇文章是关于如何使用Spring Boot整合MyBatis来连接MySQL数据库,并进行基本的增删改查操作的教程。
334 0
springboot学习五:springboot整合Mybatis 连接 mysql数据库
|
3月前
|
前端开发 Java 数据库连接
表白墙/留言墙 —— 中级SpringBoot项目,MyBatis技术栈MySQL数据库开发,练手项目前后端开发(带完整源码) 全方位全步骤手把手教学
本文是一份全面的表白墙/留言墙项目教程,使用SpringBoot + MyBatis技术栈和MySQL数据库开发,涵盖了项目前后端开发、数据库配置、代码实现和运行的详细步骤。
86 0
表白墙/留言墙 —— 中级SpringBoot项目,MyBatis技术栈MySQL数据库开发,练手项目前后端开发(带完整源码) 全方位全步骤手把手教学
|
3月前
|
Java 数据库连接 mybatis
Springboot整合Mybatis,MybatisPlus源码分析,自动装配实现包扫描源码
该文档详细介绍了如何在Springboot Web项目中整合Mybatis,包括添加依赖、使用`@MapperScan`注解配置包扫描路径等步骤。若未使用`@MapperScan`,系统会自动扫描加了`@Mapper`注解的接口;若使用了`@MapperScan`,则按指定路径扫描。文档还深入分析了相关源码,解释了不同情况下的扫描逻辑与优先级,帮助理解Mybatis在Springboot项目中的自动配置机制。
184 0
Springboot整合Mybatis,MybatisPlus源码分析,自动装配实现包扫描源码
|
4月前
|
SQL XML Java
springboot整合mybatis-plus及mybatis-plus分页插件的使用
这篇文章介绍了如何在Spring Boot项目中整合MyBatis-Plus及其分页插件,包括依赖引入、配置文件编写、SQL表创建、Mapper层、Service层、Controller层的创建,以及分页插件的使用和数据展示HTML页面的编写。
springboot整合mybatis-plus及mybatis-plus分页插件的使用
|
5月前
|
Java 数据库连接 mybatis
成功解决: Invalid bound statement (not found) 在已经使用mybatis的项目里引入mybatis-plus,结果不能共存的解决
这篇文章讨论了在已使用MyBatis的项目中引入MyBatis-Plus后出现的"Invalid bound statement (not found)"错误,并提供了解决方法,主要是通过修改yml配置文件来解决MyBatis和MyBatis-Plus共存时的冲突问题。
成功解决: Invalid bound statement (not found) 在已经使用mybatis的项目里引入mybatis-plus,结果不能共存的解决
|
5月前
|
SQL 关系型数据库 MySQL
SQL Server、MySQL、PostgreSQL:主流数据库SQL语法异同比较——深入探讨数据类型、分页查询、表创建与数据插入、函数和索引等关键语法差异,为跨数据库开发提供实用指导
【8月更文挑战第31天】SQL Server、MySQL和PostgreSQL是当今最流行的关系型数据库管理系统,均使用SQL作为查询语言,但在语法和功能实现上存在差异。本文将比较它们在数据类型、分页查询、创建和插入数据以及函数和索引等方面的异同,帮助开发者更好地理解和使用这些数据库。尽管它们共用SQL语言,但每个系统都有独特的语法规则,了解这些差异有助于提升开发效率和项目成功率。
555 0
|
6月前
|
SQL Java 数据库连接
idea中配置mybatis 映射文件模版及 mybatis plus 自定义sql
idea中配置mybatis 映射文件模版及 mybatis plus 自定义sql
122 3
|
5月前
|
Java 关系型数据库 数据库连接
|
6月前
|
XML 关系型数据库 MySQL
支付系统----微信支付19---集成MyBatis-plus,数据库驱动对应的依赖版本设置问题,5没版本没有cj这个依赖,mysql驱动默认的是版本8,这里是一个父类,数据库都有,写个父类,继承就行
支付系统----微信支付19---集成MyBatis-plus,数据库驱动对应的依赖版本设置问题,5没版本没有cj这个依赖,mysql驱动默认的是版本8,这里是一个父类,数据库都有,写个父类,继承就行