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();
    }
}
- 接口访问
  
  

 
 
                
            
         浙公网安备 33010602011771号
浙公网安备 33010602011771号