如果您正在寻找一种更好的方法来管理您的查询或想要生成动态和类型安全的查询,那么您可能会在 Spring Data JPA Specifications中找到您的解决方案。
什么是 Specifications
Spring Data JPA Specifications 是我们可以使用的另一个工具,可以使用 Spring 或 Spring Boot 执行数据库查询。
Specifications 建立在 Criteria API 之上。
当构建条件查询时,我们需要自己建立和管理Root,CriteraQuery以及CriteriaBuilder对象:
EntityManager entityManagr = getEntityManager();
CriteriaBuilder builder = entityManager.getCriteriaBuilder();
CriteriaQuery<Product> productQuery = builder.createQuery(Product.class);
Root<Person> personRoot = productQuery.from(Product.class);
Specification建立在 Criteria API 之上,以简化开发人员体验。我们只需要实现Specification接口:
interface Specification<T>{
Predicate toPredicate(Root<T> root,
CriteriaQuery<?> query,
CriteriaBuilder criteriaBuilder);
}