pageHelper的快速实现分页

本文介绍了在SpringBoot项目中如何使用PageHelper进行数据库分页查询,并创建了一个响应包装类`PageResult`,以便将查询结果以标准化格式返回给前端。详细展示了Controller、Service和Mapper层的实现方法。
摘要由CSDN通过智能技术生成

目录

1.导入依赖

2.响应包装类

3.业务逻辑实现


1.导入依赖

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

2.响应包装类

定义包装类,响应数据给前端

@ApiModel("分页数据模型")
@Data
public class PageResult<T> implements Serializable {
    /**
     * 总记录数
     */
    @ApiModelProperty(value = "总记录数")
    private Long totalRows;
    /**
     * 总页数
     */
    @ApiModelProperty(value = "总页数")
    private Integer totalPages;
    /**
     * 当前第几页
     */
    @ApiModelProperty(value = "当前第几页")
    private Integer pageNum;
    /**
     * 每页记录数
     */
    @ApiModelProperty(value = "每页记录数")
    private Integer pageSize;
    /**
     * 当前页记录数
     */
    @ApiModelProperty(value = "当前页记录数")
    private Integer size;
    /**
     * 结果集
     */
    @ApiModelProperty(value = "结果集")
    private List<T> rows;

    /**
     * 分页数据组装
     * @param pageInfo
     */
    public PageResult(PageInfo<T> pageInfo) {
        totalRows = pageInfo.getTotal();
        totalPages = pageInfo.getPages();
        pageNum = pageInfo.getPageNum();
        pageSize = pageInfo.getPageSize();
        size = pageInfo.getSize();
        rows = pageInfo.getList();
    }
}

3.业务逻辑实现

1.controller层


    @GetMapping("/page")
    public R<PageResult<StockUpDownDo>> getPageInfo( @RequestParam(value = "page", required = false, defaultValue = "1") Integer page,
                                                     @RequestParam(value = "pageSize", required = false, defaultValue = "20") Integer pageSize) {
        return stockService.getPageInfo(page,pageSize);
    }

2.service层

    @Override
    public R<PageResult<StockUpDownDo>> getPageInfo(Integer page, Integer pageSize) {
       
        //1.设置分页参数,自动sql语句添加limit
        PageHelper.startPage(page, pageSize);
        //2.调用mapper查询
        List<StockUpDownDo> pageData=stockRtInfoMapper.getPageInfo();
        //3.组装PageResult对象
        PageInfo<StockUpDownDo> pageInfo = new PageInfo<>(pageData);
        PageResult<StockUpDownDo> pageResult = new PageResult<>(pageInfo);
        //4.响应数据
        return R.ok(pageResult);
    }

3.mapper层

   <select id="getPageInfo"  resultMap="BaseResultMap">
        select
        *
        from use_info 
    </select>

  • 5
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

会敲代码的小张

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值