介绍MyBatis之分页插件PageHelper。中国程序员有强!

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用版 2核4GB 50GB
简介: 这篇文章主要给大家介绍MyBatis分页插件PageHelper

1.PageHelper介绍


  • PageHelper 是做数据分页的。
  • 应用场景举例 : 比如线上购物中对于商品的评价,不可能一次从数据库中取出来所有的数据及进行展示,而是分批次取出,一次取出10条展示在页面之上,此时可以用到数据分页。
  • 这个PageHelper就相当于MySQL中的limit ,PageHelper就是帮助我们实现limit的功能。
  • 这个PageHelper不是MyBatis框架的原始组件,是国内的作者写的一个小功能组件。


2.PageHelper应用范围


  • PageHelper支持多种数据库:
  1. Oracle
  2. Mysql
  3. MariaDB
  4. SQLite
  5. Hsqldb
  6. PostgreSQL
  7. DB2 等多种数据库.....

注意 :在每种不同的数据库中,pageHelper语法格式是不同的。


3.PageHelper使用方式


这里我们使用MySQL数据库介绍

  • 第一步 :在项目的pom.xml文件中加入PageHelper依赖 (Maven坐标)
<!--加入PageHelper依赖-->
<dependency>
  <groupId>com.github.pagehelper</groupId>
  <artifactId>pagehelper</artifactId>
  <version>5.1.10</version>
</dependency>
复制代码
  • 第二步 :在项目的主配置文件(MyBatis.xml文件)中加入plugin(插件)配置。
<!--将这个PageHelper插件写入到环境配置之前-->
<plugins>
    <plugins>
    <plugin interceptor="com.github.pagehelper.PageInterceptor" >
    <!-- 设置数据库类型 Oracle,Mysql,MariaDB,SQLite,Hsqldb,PostgreSQL六种数据库-->
        <property name="dialect" value="mysql" />
    </plugin>
</plugins>
</plugins>
复制代码
  • 第三步 :在项目的接口类中创建一个使用PageHelper分页数的抽象方法。
// 使用PageHelper分页数据
List<Student> selectAll();
复制代码
  • 第四步 :配置mapper文件,查询数据库中所有的数据,之后使用PageHelper进行分页。
<!-- 查询所有的数据-->
<select id="selectAll" resultType="com.yunbocheng.entity.Student">
    select * from student order by id;
</select>
复制代码
  • 第五步 :在测试类中使用PageHelper中
@Test
public void testSelect() throws IOException {
// PageHelper.startPage 静态方法。进行分页
// pageNum : 代表第几页,从1开始。
// pageSize : 代表一页中有多少行数据。
PageHelper.startPage(2,3);
List<Student> students = dao.selectAll();
studentList.forEach( stu -> System.out.println(stu));
}
复制代码

查看输出的结果 :

  • 第一步 :使用PageHelper功能组件第一步回先计算出我们的数据有多少行。

微信截图_20220610142101.png

  • 第二步 :根据我们给出的pageNum于pageSize参数进行查询。PageHelper会自动帮我们拼接处limit语句。并帮我们计算出查询开位置与查询结束位置。

微信截图_20220610142113.png

  • 查询的结果,这个结果会查询到数据库中第三行、第四行、第五行的数据。

微信截图_20220610142121.png



相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
4天前
|
SQL XML Java
8、Mybatis-Plus 分页插件、自定义分页
这篇文章介绍了Mybatis-Plus的分页功能,包括如何配置分页插件、使用Mybatis-Plus提供的Page对象进行分页查询,以及如何在XML中自定义分页SQL。文章通过具体的代码示例和测试结果,展示了分页插件的使用和自定义分页的方法。
8、Mybatis-Plus 分页插件、自定义分页
|
5天前
|
SQL Java 数据库连接
后端框架的学习----mybatis框架(5、分页)
这篇文章介绍了如何在MyBatis框架中实现分页功能,包括使用SQL的`limit`语句进行分页和利用MyBatis的`RowBounds`对象进行分页的方法。
|
4天前
|
Java 数据库 Spring
MyBatisPlus分页插件在SpringBoot中的使用
这篇文章介绍了如何在Spring Boot项目中配置和使用MyBatis-Plus的分页插件,包括创建配置类以注册分页拦截器,编写测试类来演示如何进行分页查询,并展示了测试结果和数据库表结构。
MyBatisPlus分页插件在SpringBoot中的使用
|
21天前
|
SQL 关系型数据库 Java
mybatis-分页
1. MyBatis RowBounds分页:先查询所有结果,再进行内存分页。 2. PageHelper插件:自动识别数据库类型并添加对应分页关键字,分两步执行:添加分页查询,然后查询总数。 3. SQL分页:直接在SQL中使用`LIMIT`或`ROWNUM`等进行分页。 4. 数组分页:DAO层查询所有数据,Service层通过`subList`方法实现分页。 5. 拦截器分页:自定义拦截器对特定方法进行拦截,并在SQL语句中添加分页参数。 6. 总结:逻辑分页适合小数据量,物理分页适合大数据量避免内存溢出。物理分页优于逻辑分页。
|
23天前
|
SQL 监控 Java
IDEA插件-Mybatis Log Free日志替换
MyBatis Log Free 是一个免费的用于在 IntelliJ IDEA 中显示 MyBatis 日志的插件。它可以帮助您更方便地查看和分析 MyBatis 的 SQL 执行情况,以及定位潜在的性能问题,提高开发效率。
106 0
IDEA插件-Mybatis Log Free日志替换
|
5天前
|
SQL Java 数据库连接
后端框架的学习----mybatis框架(5、分页)
这篇文章介绍了如何在MyBatis框架中实现分页功能,包括使用SQL的`limit`语句进行分页和利用MyBatis的`RowBounds`对象进行分页的方法。
|
4天前
|
Java 关系型数据库 MySQL
1、Mybatis-Plus 创建SpringBoot项目
这篇文章是关于如何创建一个SpringBoot项目,包括在`pom.xml`文件中引入依赖、在`application.yml`文件中配置数据库连接,以及加入日志功能的详细步骤和示例代码。
|
4天前
|
数据库
elementUi使用dialog的进行信息的添加、删除表格数据时进行信息提示。删除或者添加成功的信息提示(SpringBoot+Vue+MybatisPlus)
这篇文章介绍了如何在基于SpringBoot+Vue+MybatisPlus的项目中使用elementUI的dialog组件进行用户信息的添加和删除操作,包括弹窗表单的设置、信息提交、数据库操作以及删除前的信息提示和确认。
elementUi使用dialog的进行信息的添加、删除表格数据时进行信息提示。删除或者添加成功的信息提示(SpringBoot+Vue+MybatisPlus)
|
4天前
|
Java 测试技术 数据库
mybatisPlus在Springboot中的使用
这篇文章详细介绍了如何在Spring Boot项目中集成和使用MyBatis-Plus框架,包括依赖配置、数据库设置、项目结构、实体类定义、启动类配置、Mapper接口编写以及通过单元测试进行的增删改查操作示例。
mybatisPlus在Springboot中的使用
|
4天前
|
Java 数据库连接 mybatis
基于SpringBoot+MyBatis的餐饮点餐系统
本文介绍了一个基于SpringBoot和MyBatis开发的餐饮点餐系统,包括系统的主控制器`IndexController`的代码实现,该控制器负责处理首页、点餐、登录、注册、订单管理等功能,适用于毕业设计项目。
9 0
基于SpringBoot+MyBatis的餐饮点餐系统