服务器之家

服务器之家 > 正文

Spring Data JPA实现分页Pageable的实例代码

时间:2020-12-02 13:33     来源/作者:wayne

在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

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

原文链接:http://spring4all.com/article/118

相关文章

热门资讯

2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
Intellij idea2020永久破解,亲测可用!!!
Intellij idea2020永久破解,亲测可用!!! 2020-07-29
歪歪漫画vip账号共享2020_yy漫画免费账号密码共享
歪歪漫画vip账号共享2020_yy漫画免费账号密码共享 2020-04-07
电视剧《琉璃》全集在线观看 琉璃美人煞1-59集免费观看地址
电视剧《琉璃》全集在线观看 琉璃美人煞1-59集免费观看地址 2020-08-12
最新idea2020注册码永久激活(激活到2100年)
最新idea2020注册码永久激活(激活到2100年) 2020-07-29
返回顶部