![0a33dc9505689578520c10c11d71f54c.png](https://img-blog.csdnimg.cn/img_convert/0a33dc9505689578520c10c11d71f54c.png)
上一篇文章中,我们讲了如何利用pageHelper 在mybatis中实现分页。
这里我们着重讲一下原理和源码分析。pageHelper 是Mybatis的一款插件,是通过实现Mybatis的拦截器,拦截MappedStatement的两个不同参数的query方法 实现的。
在query方法执行之前获取boundsql并根据传入的分析参数进行sql改写,最后生成新的sql(添加了Limit的sql)。生成新的Boundsql. 进而实现了分页。
我们首先看setPage方法
![d0bad42c6ff70b7c643a0ac9bf530a05.png](https://img-blog.csdnimg.cn/img_convert/d0bad42c6ff70b7c643a0ac9bf530a05.png)
在这方法中,pageHelper将分页参数设置到Page对象中
![917223a54109e60c566a8b7f58e0038b.png](https://img-blog.csdnimg.cn/img_convert/917223a54109e60c566a8b7f58e0038b.png)
我们进而查看Page对象。我们发现 其实page类 其实就是一个附加了分页属性的ArrayList子类,本质上,它是一个List
![8cf9767bf3b8c580a29b0faa4f398bc1.png](https://img-blog.csdnimg.cn/img_convert/8cf9767bf3b8c580a29b0faa4f398bc1.png)
接下来 我们执行我们正常的query方法
![e7e6acf7278c99fd2aac97f04f3bb9a6.png](https://img-blog.csdnimg.cn/img_convert/e7e6acf7278c99fd2aac97f04f3bb9a6.png)
在执行query方法的过程中,Statement类的query方法会被拦截。而进去PageHelper 中
![01202f842d191d013df90a18555f4fc5.png](https://img-blog.csdnimg.cn/img_convert/01202f842d191d013df90a18555f4fc5.png)
通过类的注解我们可以很明确的看到,拦截的是哪个类的哪个方法。
这里我们已经进入到了intercept方法中。
![87c87bd478343ecbb8cd8ed6fcda3037.png](https://img-blog.csdnimg.cn/img_convert/87c87bd478343ecbb8cd8ed6fcda3037.png)
在后面ExecutorUtil的方法中 我们可以看到sql已经被添加了limit
![9a7397577a7955ce28a49822a2df61d5.png](https://img-blog.csdnimg.cn/img_convert/9a7397577a7955ce28a49822a2df61d5.png)
最后查询出的list
![045a6495d0b64ce0ec5354d0df5b51d5.png](https://img-blog.csdnimg.cn/img_convert/045a6495d0b64ce0ec5354d0df5b51d5.png)
我们可以看到最后查询出的list 是Page类型的 也就是说 插件提供的 List的子类。