我是靠谱客的博主 文艺毛衣,最近开发中收集的这篇文章主要介绍pagehelper中找不到pageinterceptor这个类_Mybatis之PageHelper使用,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

08d86f36eecc7e7492fb926d4dc8b55a.png

pageHelper使用

pageHelper就是mybatis拦截器的一个应用,实现分页查询,支持常见的 12 种数据库的物理分页并支持多种分页方式。

pageHelper的在官网介绍的很详细了,我就一个例子来说明pagehelper的使用。

1、首先添加maven依赖,目前版本是5.1.11,pageheper会有个依赖,就是jsqlparser,解析SQL的库。

81550a3fe143d7a8fbfd1813027fafb2.png

pagehelper的maven依赖

2、在mybatis的配置文件上添加插件,可以设置helperDialect,设置数据库方言。

cd35f0e84d919f91da8fa7eef5991b25.png

配置pageInterceptor

3、在查询前需要PageHelper.startPage(pageNum,pageSize),设置当前页和每页大小。

a4377bacdcdc9c81d12561b12b5a8ecf.png

PageHelper.startPage

执行结果如下,发现多了一条count的查询,并且在真正查询的时候多了一个LIMIT操作。

执行sql【SELECT count(0) FROM bigtable】花费时间【60】

执行sql【select * from bigtable LIMIT ? 】花费时间【178】

查询条数100

下面就分析下PageHelper的源码,看看其中的奥秘......

PageHelper.startPage这个方法会生成一个Page对象,并放入ThreadLocal中,每个线程独立互不影响。

9071eb92cd8658b46d531112abac1f4b.png

PageHelper.startPage这个方法

PageInterceptor就是一个拦截器Interceptor的实现类,拦截Executor类型,并且拦截两个query方法,query这两个方法是不同的,一个4个参数,一个6个参数。intercept方法会处理这个query方法的不同,最后会调用六个参数的方法。

这个方法intercept的大概逻辑是这样的,①获取拦截方法的参数,目标对象等,query如果是四个参数补全两个参数,②如果需要分页,在执行查询前,会解析sql生成一个count查询,查所有的数据。再调用方言获取不同数据库的物理分页查询语法,最后添加的sql上面执行查询。③如果不需要分页,就执行executor.query方法查询。④把结果封装为Page对象返回,Page是继承ArrayList,我们可以使用list一样使用Page。

13bd730bb4a8985c50535bd9f6bcd6e6.png

intercept方法源码

最后

以上就是文艺毛衣为你收集整理的pagehelper中找不到pageinterceptor这个类_Mybatis之PageHelper使用的全部内容,希望文章能够帮你解决pagehelper中找不到pageinterceptor这个类_Mybatis之PageHelper使用所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(46)

评论列表共有 0 条评论

立即
投稿
返回
顶部