数据进行分页是最基础的功能,一般可以把分页分成两类:
- 逻辑分页,先查询出所有的数据缓存到内存,再根据业务相关需求,从内存数据中筛选出合适的数据进行分页。
- 物理分页 ,直接利用数据库支持的分页语法来实现,比如Mysql里面提供了分页关键词Limit
Mybatis提供了四种分页方式:
- 在Mybatis Mapper配置文件里面直接写分页SQL,这种方式比较灵活,实现也简单。
- RowBounds实现逻辑分页,也就是一次性加载所有符合查询条件的目标数据,根据分页参数值在内存中实现分页。
当然,在数据量比较大的情况下,JDBC驱动本身会做一些优化,也就是不会把所有结果存储在ResultSet里面,而是只加载一部分数据,再根据需求去数据库里面加载。这种方式不适合数据量较大的场景,而且有可能会频繁访问数据库造成比较大的压力。
- Interceptor拦截器实现,通过拦截需要分页的select语句,然后在这个sql语句里面动态拼接分页关键字,从而实现分页查询。
(如图)Interceptor是Mybatis提供的一种针对不同生命周期的拦截器,比如:
1.拦截执行器方法
2.拦截参数的处理
3.拦截结果集的处理
4.拦截SQL语法构建的处理
我们可以拦截不同阶段的处理,来实现Mybatis相关功能的扩展。这种方式的好处,就是可以提供统一的处理机制,不需要我们再单独去维护分页相关的功能。
- 插件(PageHelper)及(MyBaits-Plus、tkmybatis)框架实现这些插件本质上也是使用Mybatis的拦截器来实现的。只是他们帮我们实现了扩展和封装,节省了分页扩展封装的工作量,在实际开发中,只需要拿来即用即可。
- 总结
第一种,直接在Select语句上增加数据库提供的分页关键字,然后在应用程序里面传递当前 页,以及每页展示条数即可。
第二种,使用Mybatis提供的RowBounds对象,实现内存级别分页。
第三种,基于Mybatis里面的Interceptor拦截器,在select语句执行之前动态拼接分页关键 字。
- 粉丝福利
我把我这些年面试遇到过的题目和在网上刷题时的高频题,整理成了一个面试文档。
这个文档帮助我给我身边的同学、同事都看过,帮他们也找了一份比较好的工作。
文档主要是按框架分类建好了索引方便查找,答案也尽量写的全面。
适合准备跳槽面试、离职、在校生准备秋招春招的同学看。
现在分享给大家,可以在评论扣“578”获取哈,或者直接给我留言哈