MyBatis分页

本文涉及的产品
多模态交互后付费免费试用,全链路、全Agent
简介: MyBatis作为Java持久层框架,需结合数据库特性或插件实现分页。分页分为物理分页(如MySQL的LIMIT)和逻辑分页(内存截取),推荐使用PageHelper插件自动注入分页语句,提升开发效率与性能。需注意索引优化、深分页问题及多表关联时的兼容性,结合业务场景选择合适方案。

MyBatis作为Java持久层框架,本身未内置分页功能,需结合数据库特性或第三方插件实现。分页本质是“数据截取”,核心在于高效获取指定范围的数据并统计总量,主要分为物理分页与逻辑分页两种模式,需根据场景选择适配方案。

物理分页依托数据库原生分页语法实现,性能最优。例如MySQL通过LIMIT offset, pageSize实现,Oracle需嵌套子查询(如ROWNUM),PostgreSQL使用OFFSET与LIMIT组合。其优势在于直接减少数据库I/O,避免全量数据传输。以MySQL为例,分页SQL可写为:

sql
SELECT FROM user ORDER BY id LIMIT #{offset}, #{pageSize}
其中offset = (pageNum - 1)
pageSize,需在Java代码中计算参数。但需注意深分页问题——当offset过大时,数据库仍需扫描前N条数据,可通过“游标分页”(记录上次最大ID)或“索引优化”提升效率。

逻辑分页通过内存截取实现,适用于小数据量场景。其流程为:先执行全量查询SELECT * FROM user,再通过Java集合的subList()方法截取分页数据。此方式代码简单但性能差,数据量大时易引发内存溢出,不推荐生产环境使用。

PageHelper插件是MyBatis生态中最主流的分页解决方案。通过拦截器机制,在SQL执行前自动注入分页语句并统计总量。使用步骤如下:

引入依赖(如pagehelper与jsqlparser);
配置拦截器(Spring Boot中可通过@Bean注入PageInterceptor);
在查询方法前调用PageHelper.startPage(pageNum, pageSize),后续执行的第一个SQL将被自动分页;
返回结果通过PageInfo封装,包含分页元数据(总记录数、总页数等)。
分页优化策略需结合业务场景:

索引优化:分页字段(如排序字段)需建立索引,避免全表扫描;
禁止返回大数据字段:分页查询应避免SELECT *,减少网络传输压力;
深分页优化:百万级数据可考虑“分段查询+ID映射表”或Elasticsearch等搜索引擎;
参数校验:前端传递的页码需验证合法性(如非负整数),防止SQL注入。
对比与选择:物理分页适用于大数据量、高并发场景;逻辑分页仅适合小数据量。PageHelper通过自动生成物理分页SQL,平衡了开发效率与性能,成为企业级应用首选。但需注意:多表关联查询时,分页逻辑可能因表关联方式失效,需手动编写分页SQL;动态SQL(如WHERE条件)需与分页参数兼容,避免语法错误。

综上,MyBatis分页需结合数据库特性、数据规模及业务需求综合设计,优先采用物理分页+PageHelper的组合方案,辅以索引优化与参数校验,实现高效稳定的分页查询。

相关文章
|
7月前
|
SQL Java 数据库连接
微服务——MyBatis分页
本文介绍了分页的多种实现方式,包括自带RowBounds分页、第三方插件PageHelper分页、SQL分页、数组分页及拦截器分页。其中,RowBounds是先查询全部结果再内存分页;PageHelper通过修改SQL动态添加分页关键字;SQL分页依赖数据库自身的分页功能如`LIMIT`;数组分页则是查询全量数据后用`subList`方法截取;拦截器分页则统一在SQL后添加分页语句。最后总结逻辑分页适合小数据量,但大数据量易内存溢出;物理分页虽小数据量效率较低,但更适合大数据场景,优先推荐使用。
91 0
|
7月前
|
SQL Oracle 关系型数据库
【YashanDB知识库】Mybatis-Plus调用YashanDB怎么设置分页
【YashanDB知识库】Mybatis-Plus调用YashanDB怎么设置分页
|
5月前
|
SQL Java 数据安全/隐私保护
发现问题:Mybatis-plus的分页总数为0,分页功能失效,以及多租户插件的使用。
总的来说,使用 Mybatis-plus 确实可以极大地方便我们的开发,但也需要我们理解其工作原理,掌握如何合适地使用各种插件。分页插件和多租户插件是其中典型,它们的运用可以让我们的代码更为简洁、高效,理解和掌握好它们的用法对我们的开发过程有着极其重要的意义。
514 15
|
SQL XML Java
8、Mybatis-Plus 分页插件、自定义分页
这篇文章介绍了Mybatis-Plus的分页功能,包括如何配置分页插件、使用Mybatis-Plus提供的Page对象进行分页查询,以及如何在XML中自定义分页SQL。文章通过具体的代码示例和测试结果,展示了分页插件的使用和自定义分页的方法。
8、Mybatis-Plus 分页插件、自定义分页
|
8月前
|
XML SQL Java
十二、MyBatis分页插件
十二、MyBatis分页插件
198 17
|
8月前
|
监控 安全 数据库
【YashanDB 知识库】Mybatis-Plus 调用 YashanDB 怎么设置分页
数据库状态分为正常与异常两种情况。当出现异常时,首先查看告警列表确认问题(如实例无法连接),并尝试用数据库用户名和密码登录。若能登录,说明主实例故障已切换至备库;若无法登录或为单节点,则需进一步排查。接着检查监控项,若有数据表明主实例故障,无数据则可能是通信中断。随后检查主机上的服务是否存在,若存在但通信受限,需排查安全设置或网络;若服务不存在,可能因重启或断电导致,需手动启动相关服务。最终在YashanDB列表中确认状态恢复。
|
7月前
|
SQL Java 关系型数据库
MyBatis篇-分页
本文介绍了多种分页方式,包括自带rowbound内存分页、第三方插件pagehelper(通过修改SQL实现分页)、SQL分页(依赖limit或rownum等关键字)、数组分页(先查询全部数据再用subList分页)、拦截器分页(自定义拦截器为SQL添加分页语句)。最后总结了逻辑分页(内存分页,适合小数据量)和物理分页(直接在数据库层面分页,适合大数据量)的优缺点,强调物理分页优先于逻辑分页。
|
7月前
|
SQL Java 数据库连接
MyBatis 实现分页的机制
MyBatis 的分页机制主要依赖于 `RowBounds` 对象和分页插件。`RowBounds` 实现内存分页,适合小数据量场景,通过设定偏移量和限制条数对结果集进行筛选。而针对大数据量,则推荐使用分页插件(如 PageHelper),实现物理分页。插件通过拦截 SQL 执行,动态修改语句添加分页逻辑,支持多种数据库方言。配置插件后,无需手动调整查询方法即可完成分页操作,提升性能与灵活性。
148 0
|
7月前
|
Oracle 关系型数据库 Java
|
8月前
|
Oracle 关系型数据库 MySQL
【YashanDB 知识库】Mybatis-Plus 调用 YashanDB 怎么设置分页
**Mybatis-Plus 自动分页配置问题简介** Mybatis-Plus 是 Mybatis 的增强工具,简化 CRUD 操作并适配多种数据库,包括 YashanDB。自动分页配置错误会导致应用开发受影响。解决方法:1. 配置 pagehelper 为 oracle 或 mysql;2. 设置分页拦截器为 oracle 或 mysql。确保返回设置后的对象。正确配置后可在 service 层使用 page 方法实现自动分页。

热门文章

最新文章