JPA - 使用Page进行分页

前言

这里介绍JPA中使用Page进行分页及分页的封装,前端传递的参数类型如下形式:

?start=10&count=5

结果展示如下:
在这里插入图片描述

环境

SpringBoot 2.5.3 + JPA 2.5.3

具体实现

  • Product 控制器
import com.coisini.springbootlearn.model.Product;
import com.coisini.springbootlearn.model.common.PageCounter;
import com.coisini.springbootlearn.model.common.Paging;
import com.coisini.springbootlearn.repository.ProductRepository;
import com.coisini.springbootlearn.util.CommonUtil;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;
import org.springframework.data.domain.Pageable;
import org.springframework.data.domain.Sort;
import org.springframework.web.bind.annotation.*;

@RestController
@RequestMapping("/product")
public class ProductController {

    @Autowired
    private ProductRepository productRepository;

    /**
     * 获取商品分页数据
     * @return
     */
    @GetMapping("/getPageProduct")
    public Paging<Product> getPageSpu(@RequestParam(defaultValue = "0") Integer start,
                                         @RequestParam(defaultValue = "2") Integer count) {
        // 分页参数构造
        PageCounter pageCounter = CommonUtil.convertToPageParameter(start, count);

        // 构造分页查询信息
        Pageable page = PageRequest.of(pageCounter.getPage(), pageCounter.getCount(), Sort.by("id").descending());

        // 查询分页结果
        Page<Product> pageResult = productRepository.findAll(page);

        // 返回分页构造对象
        return new Paging<>(pageResult);
    }

}
  • Product 仓储
/**
 * @Description Product 仓储
 * @author coisini
 * @date Aug 14, 2021
 * @Version 1.0
 */
@Repository
public interface ProductRepository extends JpaRepository<Product, Long> {

}
  • Product 模型
/**
 * @Description Product 模型
 * @author coisini
 * @date Aug 15, 2021
 * @Version 1.0
 */
@Entity
@Getter
@Setter
public class Product {

    @Id
    private int id;
    private String title;

}
  • 分页请求对象
import lombok.Builder;
import lombok.Getter;
import lombok.Setter;

/**
 * @Description 分页请求对象
 * @author coisini
 * @Version 1.0
 */
@Getter
@Setter
@Builder
public class PageCounter {

    /**
     * 页码
     */
    private Integer page;

    /**
     * 数量
     */
    private Integer count;

}
  • 公用工具类
import com.coisini.springbootlearn.model.common.PageCounter;

/**
 * @Description 公用工具类
 * @author coisini
 * @Version 1.0
 */
public class CommonUtil {

    /**
     * page参数转换
     * @param start
     * @param count
     */
    public static PageCounter convertToPageParameter(Integer start, Integer count) {

        int pageNum = start / count;

        return PageCounter.builder()
                          .page(pageNum)
                          .count(count)
                          .build();
    }

}
  • 分页返回对象
import lombok.Getter;
import lombok.NoArgsConstructor;
import lombok.Setter;
import org.springframework.data.domain.Page;
import java.util.List;

/**
 * @Description 分页返回对象
 * @author coisini
 * @date Aug 15, 2021
 * @Version 1.0
 */
@Getter
@Setter
@NoArgsConstructor
public class Paging<T> {

    /**
     * 总数量
     */
    private Long total;

    /**
     * 当前请求数量
     */
    private Integer count;

    /**
     * 当前页码
     */
    private Integer page;

    /**
     * 总页码
     */
    private Integer totalPage;

    /**
     * 数据
     */
    private List<T> data;

    /**
     * 构造函数
     */
    public Paging(Page<T> pageData) {
        this.initPageParameters(pageData);
    }

    /**
     * 构造分页参数
     * @param pageData
     */
    void initPageParameters(Page<T> pageData) {
        this.total = pageData.getTotalElements();
        this.count = pageData.getSize();
        this.page = pageData.getNumber();
        this.totalPage = pageData.getTotalPages();
        this.data = pageData.getContent();
    }

}
  • 接口访问
    在这里插入图片描述
    在这里插入图片描述

- End -
- 个人笔记 -
- 仅供参考 -

  • 6
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Maggieq8324

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

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

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

打赏作者

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

抵扣说明:

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

余额充值