java spring data 分页_Spring Data JPA实现分页Pageable的实例代码

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

1、改变CustomerRepository方法​

/**

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

* @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 findByName(@Param("name") String name2,Pageable pageable);

2、增加CustomerController方法pageable

/**

* 分页

* 应用查询提示@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 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源码。

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

参考:

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值