欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

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

时间:2022-09-12 10:15:05|栏目:JAVA代码|点击:

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

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

 参考:

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

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

上一篇:如何提高java代码的重用性

栏    目:JAVA代码

下一篇:Java中synchronized的几种使用方法

本文标题:Spring Data JPA实现分页Pageable的实例代码

本文地址:http://www.codeinn.net/misctech/213476.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有