欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2023-12-03 19:02:34
在jpa中提供了很方便的分页功能,那就是pageable(org.springframework.data.domain.pageable)以及它的实现类pagereque...

在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<customer> 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<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源码。

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

 参考:

官方文档,

demo,

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