查询user表全部数据时,如果数据量过大,展示的就很不方便,此时需要分页展示所查询的数据
MyBatis可以使用第三方的插件来对功能进行扩展,采用的标签为plugins标签,分页助手PageHelper是将分页的复杂操作进行封装,使用简单的方式即可获得分页的相关数据
使用步骤
① 在pom文件中添加通用PageHelper的坐标
<!-- 分页插件坐标-->
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>3.7.5</version>
</dependency>
<dependency>
<groupId>com.github.jsqlparser</groupId>
<artifactId>jsqlparser</artifactId>
<version>0.9.1</version>
</dependency>
② 在mybatis核心配置文件mybatis-config.xml中配置PageHelper插件
<!--配置分页助手插件,-->
<plugins>
<plugin interceptor="com.github.pagehelper.PageHelper">
<!-- 配置方言-->
<property name="dialect" value="mysql"></property>
</plugin>
</plugins>
③ 测试分页数据
@Test
public void test01() throws IOException {
InputStream resourceAsStream = Resources.getResourceAsStream("mybatis-config.xml");
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);
SqlSession session = sqlSessionFactory.openSession(true);//开启事务 默认是关闭的
UserMapper userMapper = session.getMapper(UserMapper.class);
//设置分页相关参数 当前页+每页显示的条数
PageHelper.startPage(1,3);//从第2页开始展示三条数据 不等同于limit语法
// PageHelper.startPage(2,3);//从第2页开始展示三条数据 不等同于limit语法
List<User> userList = userMapper.findAll();
for (User user : userList) {
System.out.println(user);
}
//获得与分页相关参数
PageInfo<User> pageInfo = new PageInfo<User>(userList);
System.out.println("当前页:"+pageInfo.getPageNum());
System.out.println("每页显示条数:"+pageInfo.getPageSize());
System.out.println("总条数:"+pageInfo.getTotal());
System.out.println("总页数:"+pageInfo.getPages());
System.out.println("上一页:"+pageInfo.getPrePage());
System.out.println("下一页:"+pageInfo.getNextPage());
System.out.println("是否是第一个:"+pageInfo.isIsFirstPage());
System.out.println("是否是最后一个:"+pageInfo.isIsLastPage());
session.close();
}
运行两次查看运行结果
数据库中的数据为:从第一条开始
注意:
在mysql中limit语法和不等同于分页插件中PageHelper.startPage(1,3);设置的参数,
mysql中limit的语法规则为
-- LIMIT语句传入一个或两个参数
-- 传入一个参数n时,返回n条数据,从第1条开始
-- 传入两个参数时x,y x是从(x-1)条数据开始查询,返回y条数据
select * from user LIMIT 0,3
分页插件 PageHelper.startPage(1,3)的执行结果为:第一页显示前三条数据,内部已经把sql返回的结果集通过Page类封装好