Spring Boot使用PageHelper进行分页

1、引入pom包

        <dependency>
            <groupId>com.github.pagehelper</groupId>
            <artifactId>pagehelper-spring-boot-starter</artifactId>
            <version>1.2.3</version>
        </dependency>

2、封装一个分页对象

/**
 * @author helin
 * @date 2021/4/26 15:49
 * @description 分页
 */
public class Pager<T> implements Serializable {
    private int page;//分页起始页
    private int size;//每页记录数
    private T rows;//返回的记录集合
    private long total;//总记录条数

    public int getPageTotal() {
        return pageTotal;
    }
    public void setPageTotal(int pageTotal) {
        this.pageTotal = pageTotal;
    }
    private int pageTotal;//总页数
    public int getPage() {
        return page;
    }
    public void setPage(int page) {
        this.page = page;
    }
    public int getSize() {
        return size;
    }
    public void setSize(int size) {
        this.size = size;
    }
    public T getRows() {
        return rows;
    }
    public void setRows(T rows) {
        this.rows = rows;
    }
    public long getTotal() {
        return total;
    }
    public void setTotal(long total) {
        this.total = total;
    }
}

3、Controller层

    /**
     * 分页查询产品网络原型表清单
     */
    @ApiOperation(value = "分页查询产品网络原型表清单")
    @PostMapping(value = "listQueryByPage")
    public Pager<List<ProdNetOrgDesigner>> listQueryByPage(@RequestBody(required = false) Map param) {
        Object page = Optional.ofNullable(param.get("page")).orElse(1);
        Object size = Optional.ofNullable(param.get("size")).orElse(10);
        return prodNetOrgDesignerService.listQueryByPage(Integer.parseInt(page.toString()),
                Integer.parseInt(size.toString()),param);
    }

4、Service层

@Transactional(propagation=Propagation.SUPPORTS)
public Pager<List<ProdNetOrgDesigner>> listQueryByPage(int page, int size, Map param) {
// 实例化Pager对象
Pager<List<ProdNetOrgDesigner>> pager = new Pager<>();
// PageHelper进行分页
PageHelper.startPage(page,size);
// 调Dao层,注意:list必须紧跟startPage才能进行分页
List<ProdNetOrgDesigner> list = prodNetOrgDesignerDao.listQuery(param);
// 实例化PageInfo对象
PageInfo<ProdNetOrgDesigner> pageInfo = new PageInfo<>(list);
// 设置分页数量
pager.setPage(pageInfo.getPageNum());
// 设置每页条数
pager.setPageTotal(pageInfo.getPages());
// 当前页数
pager.setSize(pageInfo.getPageSize());
// 总页数
pager.setTotal(pageInfo.getTotal());
// 分页集合
pager.setRows(list);
return pager;
}

5、效果图

posted @ 2021-08-12 21:30  passex  阅读(484)  评论(0)    收藏  举报