如果你也在用 MyBatis,建议尝试该分页插件,这一定是最方便使用的分页插件。分页插件支持任何复杂的单表、多表分页。
学习任何知识都推荐查看它的官方文档:MyBatis 分页插件 PageHelper
文档里面介绍了很多,我这里谈一下我的理解,以及我觉得最好用的使用方法
使用分页插件的步骤
1.引入依赖(在 pom.xml 中添加如下依赖)
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>最新版本</version>
</dependency>
点击 PageHelper 官网的更新日志即可查看版本
2.配置插件
在 MyBatis 配置文件 mybatis-config.xml 中配置拦截器插件
要注意 plugins 在配置文件中的位置必须符合要求
<!--
plugins在配置文件中的位置必须符合要求,否则会报错,顺序如下:
properties?, settings?,
typeAliases?, typeHandlers?,
objectFactory?,objectWrapperFactory?,
plugins?,
environments?, databaseIdProvider?, mappers?
-->
<plugins>
<!-- com.github.pagehelper为PageHelper类所在包名 -->
<plugin interceptor="com.github.pagehelper.PageInterceptor">
<!-- 使用下面的方式配置参数,后面会有所有的参数介绍 -->
<property name="param1" value="value1"/>
</plugin>
</plugins>
name 对应参数名,value 对应参数的值
如:
<property name="helperDialect" value="mysql"/> 配置分页插件使用哪种方言(这里使用的是mysql),当然即使不设置分页插件也会自动检测当前的数据库链接,自动选择合适的分页方式。
<property name="reasonable" value="true"/> 分页合理化参数,默认值为false。当该参数设置为 true 时,pageNum(页码)<=0 时会查询第一页, pageNum>pages(超过总数时),会查询最后一页。默认false 时,直接根据参数进行查询。
在 Spring 配置文件中配置拦截器插件
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!-- 注意其他配置 -->
<property name="plugins">
<array>
<bean class="com.github.pagehelper.PageInterceptor">
<property name="properties">
<!--使用下面的方式配置参数,一行配置一个 -->
<value>
params=value1
</value>
</property>
</bean>
</array>
</property>
</bean>
3.在代码中使用
使用PageInfo的用法:
/获取第1页,10条内容,默认查询总数count
//开始分页,传入 pageNum(页码) 和 pageSize(每页数目)
PageHelper.startPage(1, 10);
//查询出所有的数据放到列表中
//我们只需要查询出所有的数据放到列表中,之后将列表交给 PageHelper ,PageHelper 就能提供各种方法让我们获取到关于列表的数据
List<Country> list = countryMapper.selectAll();
//用PageInfo对结果进行包装
// 将包含所有数据的列表作为参数构造 PageInfo 对象,泛型是列表中的数据类型
// PageInfo 对象的 get 系列方法可以让我们获得关于列表的各种数据
PageInfo<Country> page = new PageInfo(list);
//测试PageInfo全部属性
//PageInfo包含了非常全面的分页属性
assertEquals(1, page.getPageNum());
assertEquals(10, page.getPageSize());
assertEquals(1, page.getStartRow());
assertEquals(10, page.getEndRow());
assertEquals(183, page.getTotal());
assertEquals(19, page.getPages());
assertEquals(1, page.getFirstPage());
assertEquals(8, page.getLastPage());
assertEquals(true, page.isFirstPage());
assertEquals(false, page.isLastPage());
assertEquals(false, page.isHasPreviousPage());
assertEquals(true, page.isHasNextPage());
//想要获取关于这个分页列表的什么数据,直接调用 PageInfo 的内置方法即可。