浅谈使用PageHelper-Mybatis通用分页插件

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS SQL Server,基础系列 2核4GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: https://github.com/pagehelper/Mybatis-PageHelperMybatis 框架的分页插件 PageHelper,目前支持 Oracle,Mysql,MariaDB,SQLite,Hsqldb,PostgreSQL 等多种数据库分页。

https://github.com/pagehelper/Mybatis-PageHelper

Mybatis 框架的分页插件 PageHelper,目前支持 Oracle,Mysql,MariaDB,SQLite,Hsqldb,PostgreSQL 等多种数据库分页。

插件目前支持以下数据库的物理分页 PageAutoDialect:

static {

       //注册别名

       registerDialectAlias("hsqldb",HsqldbDialect.class);

       registerDialectAlias("h2",HsqldbDialect.class);

       registerDialectAlias("phoenix",HsqldbDialect.class);

       registerDialectAlias("postgresql",PostgreSqlDialect.class);

       registerDialectAlias("mysql",MySqlDialect.class);

       registerDialectAlias("mariadb",MySqlDialect.class);

       registerDialectAlias("sqlite",MySqlDialect.class);

       registerDialectAlias("herddb",HerdDBDialect.class);

       registerDialectAlias("oracle",OracleDialect.class);

       registerDialectAlias("oracle9i",Oracle9iDialect.class);

       registerDialectAlias("db2",Db2Dialect.class);

       registerDialectAlias("informix",InformixDialect.class);

       //解决 informix-sqli #129,仍然保留上面的

       registerDialectAlias("informix-sqli",InformixDialect.class);

       registerDialectAlias("sqlserver",SqlServerDialect.class);

       registerDialectAlias("sqlserver2012",SqlServer2012Dialect.class);

       registerDialectAlias("derby",SqlServer2012Dialect.class);

       //达梦数据库,https://github.com/mybatis-book/book/issues/43

       registerDialectAlias("dm",OracleDialect.class);

       //阿里云PPAS数据库,https://github.com/pagehelper/Mybatis-PageHelper/issues/281

       registerDialectAlias("edb",OracleDialect.class);

       //神通数据库

       registerDialectAlias("oscar",OscarDialect.class);

       registerDialectAlias("clickhouse",MySqlDialect.class);

       //瀚高数据库

       registerDialectAlias("highgo",HsqldbDialect.class);

       //虚谷数据库

       registerDialectAlias("xugu",HsqldbDialect.class);

       //人大金仓数据库

       registerDialectAlias("kingbase",PostgreSqlDialect.class);

       }

<plugins>

   <!-- com.github.pagehelper为PageHelper类所在包名 -->

   <plugin interceptor="com.github.pagehelper.PageHelper">

       <property name="dialect" value="mysql"/>

       <!-- 该参数默认为false -->

       <!-- 设置为true时,会将RowBounds第一个参数offset当成pageNum页码使用 -->

       <!-- 和startPage中的pageNum效果一样-->

       <property name="offsetAsPageNum" value="true"/>

       <!-- 该参数默认为false -->

       <!-- 设置为true时,使用RowBounds分页会进行count查询 -->

       <property name="rowBoundsWithCount" value="true"/>

       <!-- 设置为true时,如果pageSize=0或者RowBounds.limit = 0就会查询出全部的结果 -->

       <!-- (相当于没有执行分页查询,但是返回结果仍然是Page类型)-->

       <property name="pageSizeZero" value="true"/>

       <!-- 3.3.0版本可用 - 分页参数合理化,默认false禁用 -->

       <!-- 启用合理化时,如果pageNum<1会查询第一页,如果pageNum>pages会查询最后一页 -->

       <!-- 禁用合理化时,如果pageNum<1或pageNum>pages会返回空数据 -->

       <property name="reasonable" value="false"/>

       <!-- 3.5.0版本可用 - 为了支持startPage(Object params)方法 -->

       <!-- 增加了一个`params`参数来配置参数映射,用于从Map或ServletRequest中取值 -->

       <!-- 可以配置pageNum,pageSize,count,pageSizeZero,reasonable,不配置映射的用默认值 -->

       <!-- 不理解该含义的前提下,不要随便复制该配置 -->

       <property name="params" value="pageNum=start;pageSize=limit;"/>

       <!-- always总是返回PageInfo类型,check检查返回类型是否为PageInfo,none返回Page -->

       <property name="returnPageInfo" value="check"/>

   </plugin>

</plugins>


Maven配置


<!-- Pagehelper 依赖 -->

   <dependency>

     <groupId>com.github.pagehelper</groupId>

     <artifactId>pagehelper</artifactId>

     <version>5.3.2</version>

</dependency>

mybatis-config.xml主配置文件


插件插在<环境配置前面

<!--配置插件  -->

   <plugins>

       <!-- com.github.pagehelper为PageHelper类所在包名 -->

       <plugin interceptor="com.github.pagehelper.PageInterceptor"/>

   </plugins>

接口


//测试使用PageHelper

   List<User> selectALL();

Mapper

<select id="selectALL" resultType="org.example.daomain.User">

       SELECT * FROM TEST1 order by p_id

   </select>

测试类

@Test

public void selectALL(){

   SqlSession sqlSession = MyBatisUtils.getSqlSessionAuto();

   UserDao dao = sqlSession.getMapper(UserDao.class);

   //加入pagehelper的方法,分页

   //pageNum:从第1页开始

   //pagesize:每页4行数据

   PageHelper.startPage(1,4);

   List<User> users = dao.selectALL();

   users.forEach(u-> System.out.println(u));

}



7.png8.png

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
目录
相关文章
|
11天前
|
SQL Java 数据库连接
MyBatis分页
MyBatis作为Java持久层框架,需结合数据库特性或插件实现分页。分页分为物理分页(如MySQL的LIMIT)和逻辑分页(内存截取),推荐使用PageHelper插件自动注入分页语句,提升开发效率与性能。需注意索引优化、深分页问题及多表关联时的兼容性,结合业务场景选择合适方案。
51 4
|
6月前
|
SQL Java 数据库连接
微服务——MyBatis分页
本文介绍了分页的多种实现方式,包括自带RowBounds分页、第三方插件PageHelper分页、SQL分页、数组分页及拦截器分页。其中,RowBounds是先查询全部结果再内存分页;PageHelper通过修改SQL动态添加分页关键字;SQL分页依赖数据库自身的分页功能如`LIMIT`;数组分页则是查询全量数据后用`subList`方法截取;拦截器分页则统一在SQL后添加分页语句。最后总结逻辑分页适合小数据量,但大数据量易内存溢出;物理分页虽小数据量效率较低,但更适合大数据场景,优先推荐使用。
91 0
|
6月前
|
SQL Oracle 关系型数据库
【YashanDB知识库】Mybatis-Plus调用YashanDB怎么设置分页
【YashanDB知识库】Mybatis-Plus调用YashanDB怎么设置分页
|
3月前
|
Java 数据库连接 数据库
Spring boot 使用mybatis generator 自动生成代码插件
本文介绍了在Spring Boot项目中使用MyBatis Generator插件自动生成代码的详细步骤。首先创建一个新的Spring Boot项目,接着引入MyBatis Generator插件并配置`pom.xml`文件。然后删除默认的`application.properties`文件,创建`application.yml`进行相关配置,如设置Mapper路径和实体类包名。重点在于配置`generatorConfig.xml`文件,包括数据库驱动、连接信息、生成模型、映射文件及DAO的包名和位置。最后通过IDE配置运行插件生成代码,并在主类添加`@MapperScan`注解完成整合
606 1
Spring boot 使用mybatis generator 自动生成代码插件
|
4月前
|
SQL Java 数据安全/隐私保护
发现问题:Mybatis-plus的分页总数为0,分页功能失效,以及多租户插件的使用。
总的来说,使用 Mybatis-plus 确实可以极大地方便我们的开发,但也需要我们理解其工作原理,掌握如何合适地使用各种插件。分页插件和多租户插件是其中典型,它们的运用可以让我们的代码更为简洁、高效,理解和掌握好它们的用法对我们的开发过程有着极其重要的意义。
508 15
|
7月前
|
监控 安全 数据库
【YashanDB 知识库】Mybatis-Plus 调用 YashanDB 怎么设置分页
数据库状态分为正常与异常两种情况。当出现异常时,首先查看告警列表确认问题(如实例无法连接),并尝试用数据库用户名和密码登录。若能登录,说明主实例故障已切换至备库;若无法登录或为单节点,则需进一步排查。接着检查监控项,若有数据表明主实例故障,无数据则可能是通信中断。随后检查主机上的服务是否存在,若存在但通信受限,需排查安全设置或网络;若服务不存在,可能因重启或断电导致,需手动启动相关服务。最终在YashanDB列表中确认状态恢复。
|
6月前
|
SQL Java 关系型数据库
MyBatis篇-分页
本文介绍了多种分页方式,包括自带rowbound内存分页、第三方插件pagehelper(通过修改SQL实现分页)、SQL分页(依赖limit或rownum等关键字)、数组分页(先查询全部数据再用subList分页)、拦截器分页(自定义拦截器为SQL添加分页语句)。最后总结了逻辑分页(内存分页,适合小数据量)和物理分页(直接在数据库层面分页,适合大数据量)的优缺点,强调物理分页优先于逻辑分页。
|
6月前
|
SQL Java 数据库连接
MyBatis 实现分页的机制
MyBatis 的分页机制主要依赖于 `RowBounds` 对象和分页插件。`RowBounds` 实现内存分页,适合小数据量场景,通过设定偏移量和限制条数对结果集进行筛选。而针对大数据量,则推荐使用分页插件(如 PageHelper),实现物理分页。插件通过拦截 SQL 执行,动态修改语句添加分页逻辑,支持多种数据库方言。配置插件后,无需手动调整查询方法即可完成分页操作,提升性能与灵活性。
145 0
|
6月前
|
Oracle 关系型数据库 Java
|
7月前
|
Oracle 关系型数据库 MySQL
【YashanDB 知识库】Mybatis-Plus 调用 YashanDB 怎么设置分页
**Mybatis-Plus 自动分页配置问题简介** Mybatis-Plus 是 Mybatis 的增强工具,简化 CRUD 操作并适配多种数据库,包括 YashanDB。自动分页配置错误会导致应用开发受影响。解决方法:1. 配置 pagehelper 为 oracle 或 mysql;2. 设置分页拦截器为 oracle 或 mysql。确保返回设置后的对象。正确配置后可在 service 层使用 page 方法实现自动分页。