Spring Data JPA实现分页Pageable的实例代码
2017-07-14 10:35
886 查看
在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
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
- Spring Data JPA实现动态查询的两种方法
- Spring Data JPA 简单查询--方法定义规则(详解)
- Spring Data JPA使用Sort进行排序(Using Sort)
- SpringBoot集成Spring Data JPA及读写分离
- Spring Boot中使用Spring-data-jpa实现数据库增删查改
- 从最基本的Java工程搭建SpringMVC+SpringDataJPA+Hibernate
- Spring Data JPA 复杂/多条件组合分页查询
- 详解Spring Data JPA使用@Query注解(Using @Query)
- spring data jpa分页查询示例代码
- SpringBoot使用Spring-Data-Jpa实现CRUD操作
相关文章推荐
- EasyUi+Spring Data 实现按条件分页查询的实例代码
- Spring Data JPA实现动态条件与范围查询实例代码
- Spring Data JPA实现分页Pageable的实例代码
- Spring Data JPA+kkpager实现分页功能实例
- SpringData JPA实现CRUD,分页与多参数排序
- springBoot+easyui +spring data JPA 实现分页
- Spring Data Jpa 实现分页(Spring MVC+easyui)
- 【java】spring-data-jpa 集成hibernate实现多条件分页查询
- SpringBoot第二讲利用Spring Data JPA实现数据库的访问(二)_分页和JpaSpecificationExecutor接口介绍
- 在Spring Boot中使用Spring-data-jpa实现分页查询(转)
- Spring Data Jpa+SpringMVC+Jquery.pagination.js实现分页
- 【spring data jpa】带有条件的查询后分页和不带条件查询后分页实现
- Spring Data Jpa+SpringMVC+Jquery.pagination.js实现分页
- SpringBoot第二讲 利用Spring Data JPA实现数据库的访问(二)_分页和JpaSpecificationExecutor接口介绍
- 【spring data jpa】带有条件的查询后分页和不带条件查询后分页实现
- 在Spring Boot中使用Spring-data-jpa实现分页查询
- Spring Data JPA+kkpager实现分页功能
- Spring Data + Thymeleaf 3 + Bootstrap 4 实现分页器实例代码
- SpringBoot第二讲 利用Spring Data JPA实现数据库的访问(二)_分页和JpaSpecificationExecutor接口介绍
- 在Spring Boot中使用Spring-data-jpa实现分页查询