PageHelper补充
统计总数
Page<?> page = PageHelper.startPage(1,-1); long count = page.getTotal();
分页
pageNum - 第N页, pageSize - 每页M条数
- 只分页不统计(每次只执行分页语句)
PageHelper.startPage(N,M); List<?> pagelist = queryForList( xxx.class, "queryAll" , param);//pagelist就是分页之后的结果
- 分页并统计(每次执行2条语句,一条select count语句,一条分页语句)
适用于查询分页时数据发生变动,需要将实时的变动信息反映到分页结果上
Page<?> page = PageHelper.startPage(N,M,true); List<?> pagelist = queryForList( xxx.class , "queryAll" , param); long count = page.getTotal();
//也可以 List<?> pagelist = page.getList(); 获取分页后的结果集
查全部(不分页)
PageHelper.startPage(1,0); List<?> alllist = queryForList( xxx.class , "queryAll" , param);
其他API
String orderBy = PageHelper.getOrderBy(); //获取orderBy语句 Page<?> page = PageHelper.startPage(Object params); Page<?> page = PageHelper.startPage(pageNum, pageSize, orderBy); Page<?> page = PageHelper.startPage(pageNum, pageSize, isCount, isReasonable); //isReasonable分页合理化,null时用默认配置 Page<?> page = PageHelper.startPage(pageNum, pageSize, isCount, isReasonable, isPageSizeZero); //isPageSizeZero是否支持PageSize为0,true且pageSize=0时返回全部结果,false时分页,null时用默认配置
默认值
//RowBounds参数offset作为PageNum使用 - 默认不使用 private boolean offsetAsPageNum = false; //RowBounds是否进行count查询 - 默认不查询 private boolean rowBoundsWithCount = false; //当设置为true的时候,如果pagesize设置为0(或RowBounds的limit=0),就不执行分页,返回全部结果 private boolean pageSizeZero = false; //分页合理化 private boolean reasonable = false; //是否支持接口参数来传递分页参数,默认false private boolean supportMethodsArguments = false;
补充
pageHelper什么时候会导致不安全的分页?
PageHelper 方法使用了静态的 ThreadLocal 参数,分页参数和线程是绑定的。
只要你可以保证在 PageHelper 方法调用后紧跟 MyBatis 查询方法,这就是安全的。因为 PageHelper 在 finally 代码段中自动清除了 ThreadLocal 存储的对象。
如果代码在进入 Executor 前发生异常,就会导致线程不可用,这属于人为的 Bug(例如接口方法和 XML 中的不匹配,导致找不到 MappedStatement 时), 这种情况由于线程不可用,也不会导致 ThreadLocal 参数被错误的使用。
应该写成下面这个样子:
List<Country> list; if(param1 != null){ PageHelper.startPage(1, 10); list = countryMapper.selectIf(param1); } else { list = new ArrayList<Country>(); }
这种写法就能保证安全
作者:JackpotHan
欢迎任何形式的转载,但请务必注明出处。
限于本人水平,如果文章和代码有表述不当之处,还请不吝赐教。
分类:
Spring Boot
, SSM
标签:
mybatis
, pagehelper
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 一文读懂知识蒸馏
· 终于写完轮子一部分:tcp代理 了,记录一下