我在基于 Spring 数据 JPA 的应用程序中使用 JPA Criteria API。我的服务类使用静态方法来检索Specifications
,然后可以将它们组合在一起以形成特定的查询。例如
repository.findAll(where(matchById(str)).or(matchByName(str)))
在这里,我使用了两种返回 Specifications 的方法,并应用了适当的标准。这就是这两种方法的样子
public static Specification<SomeEntity> matchById(String str) {
return (root, criteriaQuery, cb) ->
cb.like(root.get(SomeEntity_.id).as(String.class), str + "%");
}
public static Specification<SomeEntity> matchByName(String str) {
return (root, criteriaQuery, cb) -> {
cb.or(cb.like(cb.lower(root.get(SomeEntity_.firstName)), str.toLowerCase() + "%"),
cb.like(cb.lower(root.get(SomeEntity_.lastName)), str.toLowerCase() + "%")
);
}
这工作正常。我想添加一个
root.fetch(SomeEntity_.employee, JoinType.INNER);
这样一来,使用静态规范方法的任意组合构建的所有查询都使用FETCH JOIN
.
如果我将此语句添加到两个静态方法中,则 INNER JOIN 会应用两次,这似乎不正确。理想情况下,我认为我应该有另一个只应用FETCH JOIN
并返回规范的静态方法,但我似乎无法弄清楚如何在Predicate
不使用任何criteriaBuilder
方法的情况下返回 a。为了澄清,这就是我的方法应该是这样的:
public static Specification<SomeEntity> start() {
return (root, criteriaQuery, criteriaBuilder) -> {
root.fetch(SomeEntity_.employee, JoinType.INNER);
// NOW RETURN WHAT ???
return null;
};
}
任何帮助,将不胜感激。