springboot使用pagehelper

1、导入依赖

<!--pagehelper   mybatis的分页插件依赖-->
<dependency>
    <groupId>com.github.pagehelper</groupId>
    <artifactId>pagehelper-spring-boot-starter</artifactId>
    <version>1.4.3</version>
</dependency>

2、配置

#pageHelper配置(官网推荐配置)
pagehelper:
  helperDialect: mysql
  reasonable: true
  supportMethodsArguments: true
  params: count=countSql

3、使用

使用PageHelper.startPage 静态方法调用startPage :
特点:

  1. 静态方法,传递两个参数(当前页码,每页查询条数)

  2. 使用pageHelper 分页的时候,不再关注分页语句,查询全部的语句

  3. 自动的对PageHelper.startPage 方法下的第一个sql 查询进行分页

    PageHelper.startPage(1,5);
    //紧跟着的第一个select 方法会被分页
    List<Country> list = countryMapper.findAll();
    

也就是说再Service层PageHelper.startPage(1,5);语句后一定是紧跟查询语句。

Service层示例代码

public PageInfo selectUserListByPage() {
        PageHelper.startPage(1,3);
        List<BlogSysUser> list = userMapper.selectAllUser();
        PageInfo pageInfo = new PageInfo(list);
        return pageInfo;
    }

返回的信息就是pageInfo对象,该类是插件里的类,这个类里面的属性还是值得看一看

public class PageInfo<T> implements Serializable {
private static final long serialVersionUID = 1L;
//当前页
private int pageNum;
//每页的数量
private int pageSize;
//当前页的数量
private int size;
//由于startRow 和endRow 不常用,这里说个具体的用法
//可以在页面中"显示startRow 到endRow 共size 条数据"
//当前页面第一个元素在数据库中的行号
private int startRow;
//当前页面最后一个元素在数据库中的行号
private int endRow;
//总记录数
private long total;
//总页数
private int pages;
//结果集
private List<T> list;
//前一页
private int prePage;
//下一页
private int nextPage;
//是否为第一页
private boolean isFirstPage = false;
//是否为最后一页
private boolean isLastPage = false;
//是否有前一页
private boolean hasPreviousPage = false;
//是否有下一页
private boolean hasNextPage = false;
//导航页码数
private int navigatePages;
//所有导航页号
private int[] navigatepageNums;
//导航条上的第一页
private int navigateFirstPage;
//导航条上的最后一页
private int navigateLastPage;
}
posted @ 2022-08-12 19:35  z-laoyao  阅读(1347)  评论(0编辑  收藏  举报