Mybatis分页插件PageHelper的分页原理剖析
作者:信仰_273993243
前言
先说下大致的流程:PageHelper作为一个启动器,那么就和其他启动器加载一样,先读取spring.factories文件里面配置的类,转成Bean加载本系统中
然后执行他的前置后置处理方法,完成初始化,最后当我们执行目标方法时,通过拦截器对目标方法进行拦截,以达到拓展的目的。
一、加载启动器里面的Bean
1、PageHelper的spring.factories
2、里面就包含一个PageHelperAutoConfiguration类这是一个配置类,看下有哪些内容
在方法org.springframework.core.io.support.SpringFactoriesLoader#loadSpringFactories里面会去加载其他Jar下面的spring.factories文件,然后把文件下配置的类扫描添加到Map里面去。
3、那么spring是在哪里把jar包下面的spring.factories扫描进去的
其他starter的spring.factories加载也是如此
4、加载完之后需要把这个Bean注册到Spring容器中
因为是一个Configuration,所以基本注册成Bean都是在ConfigurationClassPostProcessor里面完成
最终会: org.springframework.context.annotation.ConfigurationClassBeanDefinitionReader#registerBeanDefinitionForImportedConfigurationClass 方法里面把PageHelperAutoConfiguration注册到Spring容器中
下面看下PageHelperAutoConfiguration有什么作用
二、实例化PageHelperAutoConfiguration
该方法在实例化Bean的时候,调用BeanPostProcessorsBefore回调方法会触发下面的方法
往sql拦截器链中添加拦截器
三、使用
先看下分页查询的代码
其中有个setLocalPage,就是利用ThreadLocal,设置变量值
public abstract class PageMethod { protected static final ThreadLocal<Page> LOCAL_PAGE = new ThreadLocal<Page>(); protected static boolean DEFAULT_COUNT = true; /** * 设置 Page 参数 * * @param page */ protected static void setLocalPage(Page page) { LOCAL_PAGE.set(page); } }
最终在执行sql查询的时候,会触发到拦截器
看下这个拦截器做了什么?
主要是判断是否需要分页,是否需要count操作,等等,最后返回List
到此这篇关于Mybatis分页插件PageHelper的分页原理剖析的文章就介绍到这了,更多相关PageHelper的分页原理内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!