MyBatis 实现分页的机制

简介: MyBatis 的分页机制主要依赖于 `RowBounds` 对象和分页插件。`RowBounds` 实现内存分页,适合小数据量场景,通过设定偏移量和限制条数对结果集进行筛选。而针对大数据量,则推荐使用分页插件(如 PageHelper),实现物理分页。插件通过拦截 SQL 执行,动态修改语句添加分页逻辑,支持多种数据库方言。配置插件后,无需手动调整查询方法即可完成分页操作,提升性能与灵活性。

MyBatis 实现分页的机制主要基于两个方面:RowBounds 对象和分页插件。

1. 使用 RowBounds 进行内存分页

RowBounds 是 MyBatis 提供的一种基于内存的分页方式。通过在查询方法中传入 RowBounds 参数,可以实现对结果集的内存分页。例如:

scss

代码解读

复制代码

List<User> getUsers(SqlSession sqlSession, RowBounds rowBounds);

在 SQL 中不需要添加具体的分页逻辑,而是将分页的控制权交给 RowBounds 对象,MyBatis 会根据 RowBounds 的设定在内存中进行分页操作。这种方式适用于数据量较小的情况。

2. 使用分页插件进行物理分页

对于数据量较大的情况,通常需要使用物理分页。这时可以借助 MyBatis 的分页插件,例如 MyBatis 提供的 PageHelper 插件。

分页插件的基本原理是通过 MyBatis 提供的插件接口,在 SQL 执行前后进行拦截,然后修改原始的 SQL 语句,添加对应的物理分页逻辑。

具体步骤如下:

  1. **实现 Interceptor 接口:**编写一个类实现 MyBatis 的 Interceptor 接口,重写 intercept 方法,在该方法中对 SQL 进行拦截和修改。

typescript

  1. 代码解读
  2. 复制代码
@Intercepts({@Signature(type = StatementHandler.class, method = "prepare", args = {Connection.class, Integer.class})})
public class PaginationInterceptor implements Interceptor {

    @Override
    public Object intercept(Invocation invocation) throws Throwable {
        // 对 SQL 进行拦截和修改的逻辑
        // ...
        return invocation.proceed();
    }

    @Override
    public Object plugin(Object target) {
        return Plugin.wrap(target, this);
    }

    @Override
    public void setProperties(Properties properties) {
        // 设置插件的属性
        // ...
    }
}
  1. **配置插件:**在 MyBatis 配置文件中配置该插件。

xml

  1. 代码解读
  2. 复制代码
<plugins>
    <plugin interceptor="com.example.PaginationInterceptor">
        <!-- 插件的属性配置 -->
        <!-- ... -->
    </plugin>
</plugins>
  1. **使用分页插件:**在需要分页的查询方法中,不需要手动添加分页逻辑,分页插件会根据配置自动拦截并修改 SQL。

csharp

  1. 代码解读
  2. 复制代码
List<User> getUsers();

分页插件的具体实现可以根据需求而定,一般来说,它会根据数据库的方言(Dialect)添加对应的分页语句,同时支持配置页码、每页数量等参数。 PageHelper 是 MyBatis 中常用的分页插件,可以简化分页的配置和使用。


转载来源:https://juejin.cn/post/7308134155606867983

目录
打赏
0
0
0
0
171
分享
相关文章
微服务——MyBatis分页
本文介绍了分页的多种实现方式,包括自带RowBounds分页、第三方插件PageHelper分页、SQL分页、数组分页及拦截器分页。其中,RowBounds是先查询全部结果再内存分页;PageHelper通过修改SQL动态添加分页关键字;SQL分页依赖数据库自身的分页功能如`LIMIT`;数组分页则是查询全量数据后用`subList`方法截取;拦截器分页则统一在SQL后添加分页语句。最后总结逻辑分页适合小数据量,但大数据量易内存溢出;物理分页虽小数据量效率较低,但更适合大数据场景,优先推荐使用。
24 0
【YashanDB知识库】Mybatis-Plus调用YashanDB怎么设置分页
【YashanDB知识库】Mybatis-Plus调用YashanDB怎么设置分页
mybatis复习05,mybatis的缓存机制(一级缓存和二级缓存及第三方缓存)
文章介绍了MyBatis的缓存机制,包括一级缓存和二级缓存的配置和使用,以及如何整合第三方缓存EHCache。详细解释了一级缓存的生命周期、二级缓存的开启条件和配置属性,以及如何通过ehcache.xml配置文件和logback.xml日志配置文件来实现EHCache的整合。
mybatis复习05,mybatis的缓存机制(一级缓存和二级缓存及第三方缓存)
MyBatis篇-分页
本文介绍了多种分页方式,包括自带rowbound内存分页、第三方插件pagehelper(通过修改SQL实现分页)、SQL分页(依赖limit或rownum等关键字)、数组分页(先查询全部数据再用subList分页)、拦截器分页(自定义拦截器为SQL添加分页语句)。最后总结了逻辑分页(内存分页,适合小数据量)和物理分页(直接在数据库层面分页,适合大数据量)的优缺点,强调物理分页优先于逻辑分页。
【YashanDB 知识库】Mybatis-Plus 调用 YashanDB 怎么设置分页
数据库状态分为正常与异常两种情况。当出现异常时,首先查看告警列表确认问题(如实例无法连接),并尝试用数据库用户名和密码登录。若能登录,说明主实例故障已切换至备库;若无法登录或为单节点,则需进一步排查。接着检查监控项,若有数据表明主实例故障,无数据则可能是通信中断。随后检查主机上的服务是否存在,若存在但通信受限,需排查安全设置或网络;若服务不存在,可能因重启或断电导致,需手动启动相关服务。最终在YashanDB列表中确认状态恢复。
|
2月前
|
十二、MyBatis分页插件
十二、MyBatis分页插件
83 17
8、Mybatis-Plus 分页插件、自定义分页
这篇文章介绍了Mybatis-Plus的分页功能,包括如何配置分页插件、使用Mybatis-Plus提供的Page对象进行分页查询,以及如何在XML中自定义分页SQL。文章通过具体的代码示例和测试结果,展示了分页插件的使用和自定义分页的方法。
8、Mybatis-Plus 分页插件、自定义分页
【YashanDB 知识库】Mybatis-Plus 调用 YashanDB 怎么设置分页
**Mybatis-Plus 自动分页配置问题简介** Mybatis-Plus 是 Mybatis 的增强工具,简化 CRUD 操作并适配多种数据库,包括 YashanDB。自动分页配置错误会导致应用开发受影响。解决方法:1. 配置 pagehelper 为 oracle 或 mysql;2. 设置分页拦截器为 oracle 或 mysql。确保返回设置后的对象。正确配置后可在 service 层使用 page 方法实现自动分页。
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
MyBatis-Plus是一个MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。本文讲解了最新版MP的使用教程,包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段等核心功能。
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段