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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 这篇文章主要给大家介绍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



相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
6天前
|
SQL XML Java
程序员都要懂的SQL防注入Mybatis框架SQL防注入
程序员都要懂的SQL防注入Mybatis框架SQL防注入
24 0
|
6天前
SpringBoot+Mybatis-Plus+PageHelper分页+多条件查询
SpringBoot+Mybatis-Plus+PageHelper分页+多条件查询
31 0
|
6天前
Mybatis+mysql动态分页查询数据案例——分页工具类(Page.java)
Mybatis+mysql动态分页查询数据案例——分页工具类(Page.java)
29 1
|
6天前
|
SQL Java 数据库连接
【mybatis】第一篇,Springboot中使用插件PageHelper不生效解决方案
【mybatis】第一篇,Springboot中使用插件PageHelper不生效解决方案
|
5天前
|
SQL 存储 算法
Mybatis-Plus- CRUD接口-主键策略-自动填充和乐观锁-分页-逻辑删除-条件构造器和常用接口
Mybatis-Plus- CRUD接口-主键策略-自动填充和乐观锁-分页-逻辑删除-条件构造器和常用接口
|
6天前
|
SQL 前端开发 Java
通过使用Mybatis插件来实现数据的分页功能
通过使用Mybatis插件来实现数据的分页功能
|
6天前
|
SQL XML Java
Mybatis-Plus插件扩展MybatisX
Mybatis-Plus插件扩展MybatisX
27 0
|
6天前
最新版 MyBatisPlus 分页插件(直接拿来就可以用)
最新版 MyBatisPlus 分页插件(直接拿来就可以用)
9 0
|
6天前
|
SQL Java 数据库连接
Mybatis技术专题(3)MybatisPlus自带强大功能之多租户插件实现原理和实战分析
Mybatis技术专题(3)MybatisPlus自带强大功能之多租户插件实现原理和实战分析
99 1
|
6天前
|
SQL Java 数据库连接
Mybatis是如何实现分页功能的
Mybatis是如何实现分页功能的
12 0