前言
分页是我们在开发中绕不过去的一个坎!当你的数据量大了的时候,一次性将所有数据查出来不现实,所以我们一般都是分页查询的,减轻服务端的压力,提升了速度和效率!也减轻了前端渲染的压力!
注意:由于 java 允许的最大整数为 2147483647,所以 limit 能使用的最大整数也是 2147483647,一次性取出大量数据可能引起内存溢出,所以在大数据查询场合慎重使用!
一、Limit分页
语法:
在实际项目中我们一般会加上为空为null判断,如下:
业务层代码:
执行结果:
传入0,10时:
总结:
limit 0,10;0 代表从第0条数据开始10 代表查10条数据等到第二页的时候就是 limit 10,10;
以此类推!
这些内容其实就时MySQL中的内容,不作再详细讲解了。
二、RowBounds分页(不推荐使用)
RowBounds帮我们省略了limit的内容,我们只需要在业务层关注分页即可!无须再传入指定数据!
但是,这个属于逻辑分页,即实际上sql查询的是所有的数据,在业务层进行了分页而已,比较占用内存,而且数据更新不及时,可能会有一定的滞后性!不推荐使用!
RowBounds对象有2个属性,offset和limit。
offset:起始行数limit:需要的数据行数
因此,取出来的数据就是:从第offset+1行开始,取limit行
业务层代码:
执行查看结果:
三、Mybatis_PageHelper分页插件
官方GitHub地址:
https://github.com/pagehelper/Mybatis-PageHelper
引入jar包
配置MyBatis核心配置文件
业务层代码
执行结果
总结:
PageHelper还是很好用的,也是物理分页!
实际上我们一般用第二种比较多:Mapper接口方式的调用
拓展
这种方式十分方便快捷好用!推荐使用!
篇幅有限,不可能所有用法都演示一遍!有兴趣的小伙伴可以自行测试一遍!
悄悄的说,反正我是全部试了一遍,还整合了Spring,加了拦截器测试了!
到此这篇关于详解mybatis三种分页方式的文章就介绍到这了,更多相关mybatis分页内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
您可能感兴趣的文章:Java使用MyBatis框架分页的5种方式Mybatis分页的4种方式实例Java中mybatis的三种分页方式
Powered by Artyfact中文网 @2013-2022 RSS地图 HTML地图
Copyright Powered by站群系统 © 2013-2024