本文主要是介绍Java知识点:Specification实现分页动态查询,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
目录
1. 什么是Specification接口?
2. Specification接口中定义的方法
3. 方法名称和SQL对应关系
4. Specification使用示例
4.1 首先,对应的Repository需要实现JpaSpecificationExecutor接口
4.2 然后,在业务类service中,分页查询的方法如下
1. 什么是Specification接口?
Spring Data JPA中可以通过JpaSpecificationExecutor接口实现动态/分页查询。
而JpaSpecificationExecutor是围绕着Specification接口来定义的。
可理解为:Specification构造的就是查询条件。
2. Specification接口中定义的方法
该接口中只定义了一个方法:
//构造查询条件
/**
* root :Root接口,代表查询的根对象,可以通过root获取实体中的属性
* query :代表一个顶层查询对象,用来自定义查询
* cb :用来构建查询,此对象里有很多条件方法
**/
public Predicate toPredicate(Root<T> root, CriteriaQuery<?> query, CriteriaBuilder cb);
3. 方法名称和SQL对应关系
4. Specification使用示例
4.1 首先,对应的Repository需要实现JpaSpecificationExecutor接口
4.2 然后,在业务类service中,分页查询的方法如下
public Page<PerfCase> findPerfCases(PagingQueryPerfCaseDto paging){//分页查询的因素:perfCaseName, current, pageSizeString perfCaseName = paging.getPerfCaseName();Integer current = paging.getCurrent();Integer pageSize = paging.getPageSize();//查询条件. 添加先关的查询条件,类似于where后面的语句//写法一Specification<PerfCase> specification = (root, criteriaQuery, criteriaBuilder) -> {List<Predicate> predicateList = new ArrayList<>();if(perfCaseName != null && !"".equals(perfCaseName.trim())){predicateList.add(criteriaBuilder.like(root.get("perfCaseName"), "%"+perfCaseName+"%"));}predicateList.add(criteriaBuilder.equal(root.get("isDelete"), 0));return criteriaBuilder.and(predicateList.toArray(new Predicate[predicateList.size()]));};/* 写法二//使用匿名内部类的方式,创建一个Specification的实现类,并实现toPredicate方法//criteriaBuilder:构建查询,添加查询方式 //like:模糊匹配//root:从实体PerfCase对象中按照perfCaseName属性进行查询Specification<PerfCase> specification2 = new Specification<PerfCase>() {@Overridepublic Predicate toPredicate(Root<PerfCase> root, CriteriaQuery<?> query, CriteriaBuilder criteriaBuilder) { List<Predicate> predicates = new ArrayList<>();if (perfCaseName != null && !"".equals(perfCaseName.trim())) {predicates.add(criteriaBuilder.like(root.get("perfCaseName"), "%" + perfCaseName + "%"));}predicates.add(criteriaBuilder.equal(root.get("isDelete"), 0));return criteriaBuilder.and(predicates.toArray(new Predicate[predicates.size()]));}};*///排序Sort.Order order = new Sort.Order(Sort.Direction.DESC, "updateTime");Sort sort = Sort.by(order);//分页/*** 构造分页参数* Pageable : 接口* PageRequest实现了Pageable接口,调用构造方法的形式构造* 第一个参数:页码(从current-1开始)* 第二个参数:每页查询条数*/Pageable pageable = PageRequest.of(current-1, pageSize, sort);//分页查询/*** 分页查询,封装为Spring Data Jpa 内部的page bean* 此重载的findAll方法为分页方法需要两个参数* 第一个参数:查询条件Specification* 第二个参数:分页参数*/Page<PerfCase> perfCases = perfCaseRepo.findAll(specification, pageable);return perfCases;}
解析:
(1)
这篇关于Java知识点:Specification实现分页动态查询的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!