开发工具分享
  • 首页
  • 计算科学
  • 文化旅游
  • 项目和网站
    • OSSEZ 计算技术
    • USRealEstate 社区
    • 地区文化
    • CWIKI.US
    • BUG.OSSEZ.COM
    • RSS.OSSEZ.COM
CWIKIUS.CN
一个有独立思考和温度的清新站
  1. Home
  2. Computer Science
  3. This article

Spring Data @Repository 的分页查询

2022年09月18日 667Browse 0Like 0Comments

分页查询在网站的设计中必不可少。

分页查询有几种方式,通常用的是:网页分页和后端分页。

不要觉得现在还有人用网页分页的方式吗?

相信我,奇葩远比想象得多。经历过一个项目,全部都是网页分页,后端都是大量的 JOIN 和毫无人性的返回几千条记录。

为什么不返回上万条?那是因为后台数据库不大,只有 5 万多点的数据量。连个 Limit 都懒得用的项目还堂而皇之的上线运行了好几年到不重做差不多就没法用的地步。

我们来说说基于 Spring Data 的分页查询。

如果项目使用的是 Spring Data,那么恭喜你,这分页太方便了。

PagingAndSortingRepository 接口

首先你的实体仓库类,需要继承 PagingAndSortingRepository 这个接口。

写法也简单到只写一个继承就可以了。

 

2022-09-11_10-26-54

 

PagingAndSortingRepository 接口继承于 CrudRepository 接口,拥有CrudRepository 接口的所有方法, 并新增两个功能:分页和排序。

Service

Service 层也简单到不能再简单了。

假设我们希望查询一个实体类的所有数据,但是我们希望进行分页。

我们可以简单到

    public Page<Visa> findAllVisa(Pageable pageable) {
        return visaRepository.findAll(pageable);
    }

只写这一段话就可以了。

我们只需要把 pageable 作为参数传递进去就行了。

Pageable 是一个接口。

定义分页对象

要对实体数据进行分页,我们需要让实体数据知道后面查询的时候是怎么分页的。

在服务层或者控制层定义一个 Pageable 对象。

 

2022-09-11_10-31-12

 

        if (ObjectUtils.isEmpty(searchCondition)) {
            Pageable visaPage = PageRequest.of(pageNumber, 100, Sort.by("dateVisaInterview").descending());
            pageableResponse.setPagedData(visaService.findAllVisa(visaPage));
        }

在这个对象中,我们创建了一个 visaPage 分页对象。

在这个分页对象中,我们提供了参数:

  1. 分页的当前页
  2. 每一个页面的大小
  3. 排序字段

返回

在分页查询的结果都会返回一个叫做 Page 的对象。

Page 是一个接口,继承的 Slice。

2022-09-11_10-33-50

为了让程序更加简单,我们直接定义了一个返回的对象。将 Page 的内容返回到 API 上。

运行结果

如果 API 运行没有问题的话,在 API 的返回中,我们可以看到下面的信息。

 

Snag_700752

 

针对分页查询的所有信息都有了。

包括有当前页,页大小,偏移量,总数据量。

使用 Spring Data 的分页查询,能够大大加快程序的处理,甚至能够让程序员不再关注后端是如何获得查询数据和如何进行查询的。

真的是一个非常贴心的接口。

 

https://www.ossez.com/t/spring-data-repository/14097

Tags: None
Last updated:2022年09月18日

HoneyMoose

有温度的人文和独立的思考

Like
< Previous
Next >

Comments

Cancel reply

Archives
  • May 2026
  • April 2026
  • March 2026
  • February 2026
  • January 2026
  • December 2025
  • November 2025
  • October 2025
  • September 2025
  • August 2025
  • July 2025
  • June 2025
  • May 2025
  • April 2025
  • March 2025
  • February 2025
  • January 2025
  • December 2024
  • November 2024
  • October 2024
  • September 2024
  • August 2024
  • July 2024
  • June 2024
  • May 2024
  • April 2024
  • March 2024
  • February 2024
  • January 2024
  • December 2023
  • November 2023
  • October 2023
  • September 2023
  • August 2023
  • July 2023
  • June 2023
  • May 2023
  • April 2023
  • December 2022
  • November 2022
  • October 2022
  • September 2022
  • August 2022
  • May 2022
  • April 2022
  • March 2022
  • February 2022
  • January 2022
  • December 2021
  • November 2021
  • October 2021
  • September 2021
  • August 2021
  • July 2021
  • June 2021
  • May 2021
  • April 2021
  • March 2021
  • February 2021
  • January 2021
  • December 2020
  • November 2020
  • October 2020
  • September 2020
  • August 2020
  • July 2020
  • June 2020
  • May 2020
  • April 2020
  • March 2020
  • February 2020
  • January 2020
  • December 2019
  • November 2019
  • October 2019
  • September 2019
  • August 2019
  • July 2019
  • June 2019
  • May 2019
  • April 2019
  • March 2019
  • February 2019
  • January 2019
  • December 2018
  • November 2018
  • October 2018
  • September 2018
  • August 2018
  • July 2018
  • June 2018
  • May 2018
  • April 2018
  • March 2018
Categories
  • Computer Science (2,362)
    • Confluence (663)
    • Gradle (12)
  • U.S. (482)
  • 文化旅游 (145)

COPYRIGHT © 2020 CWIKIUS. ALL RIGHTS RESERVED.

THEME KRATOS MADE BY VTROIS

湘ICP备2020018253号-1