当前位置: 首页 > article >正文

别再只会用PageHelper了!MyBatis-Plus的Page分页实战,从Controller到XML完整流程拆解

别再只会用PageHelper了MyBatis-Plus的Page分页实战全流程解析如果你还在项目里用PageHelper处理分页是时候试试MyBatis-Plus的分页方案了。作为一个深度整合MyBatis的增强工具包MyBatis-Plus的分页机制不仅更符合Spring Boot项目的开发习惯还能避免PageHelper带来的线程安全问题。最近在重构一个用户管理系统时我把所有PageHelper的分页逻辑都迁移到了MyBatis-Plus上整个过程比想象中顺利得多。1. 为什么选择MyBatis-Plus分页在开始代码实战前我们先理清几个关键问题。MyBatis-Plus的分页到底比PageHelper强在哪为什么越来越多的项目开始采用这种方案性能对比实测数据基于10万条用户数据测试指标PageHelperMyBatis-Plus平均查询耗时(ms)142128内存占用(MB)3528线程安全否是与MyBatis整合度中等深度整合实际使用中MyBatis-Plus分页最让我惊喜的是它的无侵入性。不需要像PageHelper那样在每次查询前调用静态方法只需要在配置类声明分页插件剩下的工作都会自动完成Configuration public class MybatisPlusConfig { Bean public MybatisPlusInterceptor mybatisPlusInterceptor() { MybatisPlusInterceptor interceptor new MybatisPlusInterceptor(); interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL)); return interceptor; } }2. 核心分页对象解析MyBatis-Plus提供了两种分页对象很多开发者刚开始会混淆它们的用途2.1 Page与IPage的区别Page是具体实现类通常在Service层初始化分页参数时使用PageUser page new Page(1, 10); // 当前页1每页10条IPage是接口类型推荐作为方法参数和返回值类型提高代码的扩展性public interface UserService { IPageUserVO selectPage(IPageUserVO page, UserQuery query); }实际开发建议Controller层接收参数使用IPageService层实现类内部使用Page构造分页条件Mapper层方法参数保持为IPage2.2 分页对象的关键方法// 构建分页对象并设置扩展参数 PageUser page new Page(current, size); page.setSearchCount(false); // 禁用count查询提升性能 // 链式调用示例 ListUser records userMapper.selectPage(page, Wrappers.UserlambdaQuery() .eq(User::getStatus, 1) .orderByDesc(User::getCreateTime) ).getRecords();注意当不需要返回总记录数时务必设置searchCount为false这对大表分页性能提升显著3. 完整分页流程实战下面我们以实现一个带条件查询的用户分页接口为例展示从Controller到XML的完整调用链。3.1 Controller层设计RestController RequestMapping(/users) Api(tags 用户管理) public class UserController { Autowired private UserService userService; GetMapping public RIPageUserVO pageUsers( RequestParam(required false) String username, RequestParam(required false) Integer status, RequestParam(defaultValue 1) Integer current, RequestParam(defaultValue 10) Integer size) { // 构建分页对象 IPageUserVO page new Page(current, size); // 构建查询条件 UserQuery query new UserQuery(username, status); // 调用服务 return R.success(userService.pageUsers(page, query)); } }3.2 Service层实现Service public class UserServiceImpl implements UserService { Autowired private UserMapper userMapper; Override public IPageUserVO pageUsers(IPageUserVO page, UserQuery query) { // 类型转换 PageUserVO realPage (PageUserVO) page; // 设置不需要count查询 realPage.setSearchCount(query.isNeedTotal()); return realPage.setRecords( userMapper.selectUserPage(realPage, query) ); } }3.3 Mapper与XML配置Mapper接口定义public interface UserMapper extends BaseMapperUser { ListUserVO selectUserPage( Param(page) IPageUserVO page, Param(query) UserQuery query ); }对应的XML映射文件select idselectUserPage resultTypecom.example.vo.UserVO SELECT id, username, email, status, create_time FROM user where deleted 0 if testquery.username ! null and query.username ! AND username LIKE CONCAT(%, #{query.username}, %) /if if testquery.status ! null AND status #{query.status} /if /where ORDER BY create_time DESC /select关键点XML中不需要写LIMIT语句分页参数会自动注入4. 高级技巧与避坑指南4.1 自定义Count查询优化当主查询非常复杂时可以指定专门的count查询提升性能select idselectUserPage resultTypecom.example.vo.UserVO SELECT ... /* 复杂查询 */ /select select idselectUserPageCount resultTypelong SELECT COUNT(1) FROM user /* 简化版count查询 */ where !-- 保持与主查询相同的条件 -- /where /select在Mapper接口中添加Select注解指定count方法Select(selectUserPageCount) ListUserVO selectUserPage( Param(page) IPageUserVO page, Param(query) UserQuery query );4.2 多表联查分页处理联表查询时需要特别注意分页准确性select idselectUserWithRolePage resultMapuserRoleMap SELECT u.*, r.role_name FROM user u LEFT JOIN user_role ur ON u.id ur.user_id LEFT JOIN role r ON ur.role_id r.id where u.deleted 0 /where !-- 必须排序保证分页稳定 -- ORDER BY u.create_time DESC /select对应的ResultMap配置resultMap iduserRoleMap typecom.example.vo.UserWithRoleVO id propertyid columnid/ result propertyusername columnusername/ !-- 其他字段映射 -- collection propertyroles ofTypestring result columnrole_name/ /collection /resultMap4.3 常见问题排查分页失效检查清单确认已配置分页插件检查Mapper方法参数中是否有IPage/Page参数XML中不要手动添加limit语句确保查询语句结尾有ORDER BY性能优化建议百万级以上数据考虑使用setSearchCount(false)联表查询时优先过滤驱动表数据对排序字段建立合适索引特殊数据库适配// 配置分页插件时指定数据库类型 new PaginationInnerInterceptor(DbType.ORACLE);最近在金融项目中处理千万级交易记录分页时通过组合使用MyBatis-Plus的分页优化技巧将查询响应时间从原来的4秒降低到了800毫秒左右。关键是在复杂查询场景下合理设计count查询并利用缓存机制避免重复计算总数。

相关文章:

别再只会用PageHelper了!MyBatis-Plus的Page分页实战,从Controller到XML完整流程拆解

别再只会用PageHelper了!MyBatis-Plus的Page分页实战全流程解析 如果你还在项目里用PageHelper处理分页,是时候试试MyBatis-Plus的分页方案了。作为一个深度整合MyBatis的增强工具包,MyBatis-Plus的分页机制不仅更符合Spring Boot项目的开发习…...

收藏备用|2026版AI Agent与Agentic AI彻底分清!

在2026年大模型技术持续狂飙的当下,“智能体”相关概念迎来爆发式增长,AI Agent和Agentic AI更是成为技术圈高频热词,但多数小白、甚至部分程序员都容易将二者混为一谈,踩坑走弯路。 其实二者的定位有着天壤之别:AI Ag…...

强化学习中的自适应熵策略优化(AEPO)原理与实现

1. 项目概述强化学习算法在近年来取得了显著进展,但在实际应用中仍面临着探索与利用平衡的挑战。自适应熵策略优化(Adaptive Entropy Policy Optimization,AEPO)作为一种新兴的优化方法,通过动态调整策略熵来改善这一平…...

别再纠结EEPROM了!用Cypress FM25CL64B铁电存储器做数据存储,实测读写寿命超乎想象

嵌入式存储革命:FM25CL64B铁电存储器实战指南 当你在设计需要频繁写入数据的嵌入式系统时,是否曾被EEPROM的缓慢写入速度和有限寿命所困扰?每次产品迭代都在为存储器的可靠性提心吊胆?FM25CL64B这款铁电存储器(FRAM)可能会成为改变…...

避坑指南:Python 3.7.9 + Playwright 1.9.0 保姆级安装配置(解决绿色导入、SSL证书等报错)

Python 3.7.9 Playwright 1.9.0 环境配置全攻略:从版本锁定到疑难排错 当测试自动化遇上特定版本依赖,往往意味着无数个深夜的调试与报错。如果你正在Windows 10环境下为Robot Framework搭建Python 3.7.9和Playwright 1.9.0的组合,这篇实战…...

Kubernetes Pod 状态同步机制

Kubernetes Pod状态同步机制解析 在分布式系统中,容器编排平台Kubernetes通过Pod状态同步机制确保集群资源与实际运行状态的一致性。这一机制不仅保障了应用的高可用性,还为运维人员提供了透明的状态管理能力。本文将深入探讨Pod状态同步的核心逻辑&…...

丹青识画系统快速部署指南:小白友好,轻松玩转AI影像艺术鉴赏

丹青识画系统快速部署指南:小白友好,轻松玩转AI影像艺术鉴赏 1. 认识丹青识画系统 你有没有遇到过这样的情况?看到一张触动心弦的照片,却找不到合适的文字来描述它的意境。传统的AI图像识别只能告诉你"这是一座山"、&…...

终极惠普游戏本性能管理方案:OmenSuperHub完全指南

终极惠普游戏本性能管理方案:OmenSuperHub完全指南 【免费下载链接】OmenSuperHub 使用 WMI BIOS控制性能和风扇速度,自动解除DB功耗限制。 项目地址: https://gitcode.com/gh_mirrors/om/OmenSuperHub 还在为惠普游戏本官方软件的性能限制和资源…...

告别数据焦虑:用MixMatch半监督算法,让你的小样本图像分类模型也能起飞

告别数据焦虑:用MixMatch半监督算法,让你的小样本图像分类模型也能起飞 在工业质检、医疗影像分析等领域,数据标注成本往往成为AI落地的最大瓶颈。想象一下:你需要在两周内开发一个缺陷检测系统,但产线只能提供200张标…...

从Spring Boot项目里‘偷’图:手把手教你用PlantUML插件,自动生成UML类图

从Spring Boot项目自动生成UML类图的工程实践 在真实的软件开发过程中,UML类图往往被视为文档编制的"必修课",却鲜少发挥其真正的工程价值。传统的手动绘制方式不仅效率低下,更难以与快速迭代的代码保持同步。本文将颠覆这一现状&a…...

UTM虚拟机:在iOS和macOS设备上运行Windows和Linux的终极指南

UTM虚拟机:在iOS和macOS设备上运行Windows和Linux的终极指南 【免费下载链接】UTM Virtual machines for iOS and macOS 项目地址: https://gitcode.com/gh_mirrors/ut/UTM 你是否曾梦想过在iPhone上运行Windows系统,或者在iPad上体验完整的Linux…...

Douyin-Downloader:构建抖音内容生态的智能下载引擎

Douyin-Downloader:构建抖音内容生态的智能下载引擎 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback support…...

免费GPU显存稳定性终极测试指南:memtest_vulkan 5分钟快速上手

免费GPU显存稳定性终极测试指南:memtest_vulkan 5分钟快速上手 【免费下载链接】memtest_vulkan Vulkan compute tool for testing video memory stability 项目地址: https://gitcode.com/gh_mirrors/me/memtest_vulkan 你是否曾经遇到游戏崩溃、图形渲染错…...

优化你的ROS机器人视觉:深入理解image_transport与cv_bridge的配合使用

优化你的ROS机器人视觉:深入理解image_transport与cv_bridge的配合使用 在机器人视觉开发中,图像数据的传输和处理效率直接影响着整个系统的性能表现。对于已经掌握ROS基础的中级开发者而言,如何构建一个高效、稳定的图像处理流水线是提升机器…...

从SSC生成的代码到实际跑通:我的STM32F103 EtherCAT从站移植与调试全记录

从SSC生成代码到实际运行的STM32F103 EtherCAT从站开发实战指南 1. 引言:EtherCAT从站开发的挑战与机遇 在工业自动化领域,EtherCAT凭借其卓越的实时性能和灵活的拓扑结构,已成为主流工业以太网协议之一。对于嵌入式开发者而言,实…...

抖音无水印下载工具:从单视频到批量下载的完整解决方案

抖音无水印下载工具:从单视频到批量下载的完整解决方案 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback supp…...

别再为仿真数据格式发愁!保姆级教程:为你的Livox Mid-360 Gazebo模型适配CustomMsg点云

深度解析Livox Mid-360仿真:从Gazebo建模到CustomMsg点云生成实战 在机器人感知算法开发中,激光雷达仿真一直是验证环节的关键瓶颈。特别是当硬件设备如Livox Mid-360面临供货紧张时,一套高保真的仿真方案不仅能加速研发进程,更能…...

5分钟掌握:免费高效的.NET Core Mod加载器Reloaded-II完全指南

5分钟掌握:免费高效的.NET Core Mod加载器Reloaded-II完全指南 【免费下载链接】Reloaded-II Universal .NET Core Powered Modding Framework for any Native Game X86, X64. 项目地址: https://gitcode.com/gh_mirrors/re/Reloaded-II Reloaded-II是一款基…...

别再纠结了!FreeRTOS、uC/OS-II、RT-Thread到底怎么选?给嵌入式新手的保姆级指南

嵌入式RTOS选型实战指南:从需求分析到项目落地的全流程决策 当你面对一个全新的嵌入式项目时,选择哪个实时操作系统(RTOS)往往成为第一个技术决策难题。市场上主流的FreeRTOS、uC/OS-II和RT-Thread各有特色,但网上大多…...

告别照片重复烦恼:用AntiDupl.NET智能清理你的数字相册

告别照片重复烦恼:用AntiDupl.NET智能清理你的数字相册 【免费下载链接】AntiDupl A program to search similar and defect pictures on the disk 项目地址: https://gitcode.com/gh_mirrors/an/AntiDupl 你是否曾经在整理手机相册时,发现同一张…...

终极指南:如何快速将网站转换为可编辑的Figma设计

终极指南:如何快速将网站转换为可编辑的Figma设计 【免费下载链接】figma-html Convert any website to editable Figma designs 项目地址: https://gitcode.com/gh_mirrors/fi/figma-html 在当今快节奏的数字化时代,设计师和开发者之间的协作效率…...

AI安全周记:AI驱动攻击占比50%、PQC国标落地、ShinyHunters连环袭击——面对1:25的攻防成本鸿沟,防守方还能撑多久?

当AI驱动网络攻击占比突破50%,当“先窃取、后解密”从理论变为现实,当影子AI将不安全代码扩散率推高300%——这已不是传统的“攻防”,而是一场成本完全不对等的降维打击。引言刚刚过去的一周,网络安全世界再次经历了一场从攻防模式…...

PromptUI:AI提示词驱动的UI灵感库,从截图到代码的现代全栈实践

1. 项目概述:PromptUI,一个为UI设计注入AI动力的灵感库作为一个长期在Web和移动端开发一线摸爬滚打的开发者,我深知从零开始构思一个界面有多耗神。你可能会花几个小时在Dribbble或Behance上寻找灵感,但找到的截图往往只是一个静态…...

Qwen3.5-4B-AWQ-4bit开源模型部署:腾讯云TI-ONE平台适配指南

Qwen3.5-4B-AWQ-4bit开源模型部署:腾讯云TI-ONE平台适配指南 1. 模型概述 Qwen3.5-4B-AWQ-4bit是阿里云通义千问团队推出的轻量级开源模型,采用4bit AWQ量化技术,在保持高性能的同时大幅降低资源需求。 1.1 核心优势 极致低资源&#xff…...

当InP光子芯片‘瘦身’成薄膜:IMOS技术如何解决与硅电子‘亲密接触’的散热与互连难题

InP光子芯片薄膜化革命:IMOS技术如何重塑光电融合未来 当光子芯片的厚度从数百微米缩减到几微米时,整个光电集成领域正在经历一场静默的革命。这种被称为IMOS(InP膜上硅)的技术路径,正在解决困扰业界多年的"亲密接…...

收藏|2026年新版春招大变局!后端程序员必看,大模型已成上岸刚需

正值2026年春招黄金爆发阶段,也是全体技术人求职跳槽、职级晋升的关键转折点。对比往年互联网招聘行情,今年后端求职赛道早已全面革新,不管是企业招聘考核逻辑、整体薪资走势,还是人才筛选标准,都迎来了颠覆性调整&…...

游戏资源编辑新手指南:用ExtractorSharp打造个性化游戏补丁

游戏资源编辑新手指南:用ExtractorSharp打造个性化游戏补丁 【免费下载链接】ExtractorSharp Game Resources Editor 项目地址: https://gitcode.com/gh_mirrors/ex/ExtractorSharp 你是否厌倦了游戏中千篇一律的角色外观?是否梦想为心爱的游戏角…...

GD32F103VBT6串口OTA升级保姆级教程:当硬件没留Boot0引脚时,我是如何用Keil和Ymodem搞定的

GD32F103VBT6无Boot0引脚串口OTA实战:Keil工程改造与Ymodem传输全解析 当硬件设计成为既定事实,而产品又面临远程更新的需求时,嵌入式开发者往往需要在不完美的条件下寻找最优解。GD32F103VBT6作为一款广泛应用的Cortex-M3内核MCU&#xff0…...

收藏!2026最新AI风口解读:零基础也能入行,大模型训练师年薪可达45W+

最近刷热搜的朋友,大概率都刷到了“某科技巨头拟千亿级加码AI”的重磅消息。 尽管官方尚未官宣,但明眼人都能看出:AI早已不是行业内的专属“黑话”,而是全面渗透到生活、工作、娱乐的每一个角落,成为2026年最具确定性的…...

从海洋测绘到生鲜定价:拆解2023国赛B题C题背后的通用建模思维与MATLAB/Excel实战

从海洋测绘到生鲜定价:跨领域数学建模的通用思维框架与工具实战 当数学建模遇上现实问题,领域差异往往只是表象。去年全国大学生数学建模竞赛中,B题的多波束测深系统优化与C题的生鲜蔬菜定价策略看似毫无关联,实则共享着相同的问题…...