SpringBoot JPA 带参数分页查询代码实现

举报
隔壁老汪 发表于 2022/06/24 00:34:01 2022/06/24
【摘要】 在JPA中提供了很方便的分页功能,那就是Pageable(org.springframework.data.domain.Pageable)以及它的实现类PageRequest(org.springframework.data.domain.PageRequest),详细的可以见示例代码。 1、改变CustomerRepository...

JPA中提供了很方便的分页功能,那就是Pageable(org.springframework.data.domain.Pageable)以及它的实现类PageRequest(org.springframework.data.domain.PageRequest),详细的可以见示例代码。

1、改变CustomerRepository方法​

1

2

3

4

5

6

7

8

9

10

11

12

/**

 * 一个参数,匹配两个字段

 * @param name2

 * @Param pageable 分页参数

 * @return

 * 这里Param的值和=:后面的参数匹配,但不需要和方法名对应的参数值对应

 * 这里增加了@QueryHints注解,是给查询添加一些额外的提示

 * 比如当前的name值为HINT_COMMENT是在查询的时候带上一些备注信息

 */

@QueryHints(value = { @QueryHint(name = HINT_COMMENT, value = "a query for pageable")})

@Query("select c from Customer c where c.firstName=:name or c.lastName=:name")

Page<Customer> findByName(@Param("name") String name2,Pageable pageable);

2、增加CustomerController方法pageable

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

/**

 * 分页

 * 应用查询提示@QueryHints,这里是在查询的适合增加了一个comment

 * 查询结果是lastName和firstName都是bauer这个值的数据

 */

@RequestMapping("/pageable")

public void pageable(){

  //Pageable是接口,PageRequest是接口实现

  //PageRequest的对象构造函数有多个,page是页数,初始值是0,size是查询结果的条数,后两个参数参考Sort对象的构造方法

  Pageable pageable = new PageRequest(0,3, Sort.Direction.DESC,"id");

  Page<Customer> page = repository.findByName("bauer",pageable);

  //查询结果总行数

  System.out.println(page.getTotalElements());

  //按照当前分页大小,总页数

  System.out.println(page.getTotalPages());

  //按照当前页数、分页大小,查出的分页结果集合

  for (Customer customer: page.getContent()) {

    System.out.println(customer.toString());

  }

  System.out.println("-------------------------------------------");

}

从示例代码的注释当中可以看到Page对象的相关参数及值的说明,更详细的用法,参考PageRequest源码。

小结:怎么样,是不是很简单很方便?!

 参考:

官方文档,http://docs.spring.io/spring-data/jpa/docs/current/reference/html/ 

DEMO,https://github.com/icnws/spring-data-jpa-demo

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

文章来源: blog.csdn.net,作者:隔壁老瓦,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/wxb880114/article/details/83501170

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。