【发布时间】:2017-05-12 23:17:24
【问题描述】:
假设我有以下课程:(简化到极致)
@Entity
@Table(name = "USER")
public class User {
@OneToOne(mappedBy = "user", cascade = CascadeType.ALL)
private BillingAddress billingAddress;
@OneToOne(mappedBy = "user", cascade = CascadeType.ALL)
private ShippingAddress shippingAddress; // This one CAN be null
}
*Address 都继承自这个摘要:(再次,它被额外简化了)
public abstract class Address {
@OneToOne(optional = false, fetch = FetchType.LAZY)
@JoinColumn(name = "USER_ID")
private User user;
@NotEmpty
@Size(max = 32)
@Column(name = "ADDR_TOWN")
private String town;
}
我尝试了 JPA 规范,正如 Spring 的博文所述:
/**
* User specifications.
*
* @see <a href="https://spring.io/blog/2011/04/26/advanced-spring-data-jpa-specifications-and-querydsl">Advanced Spring Data JPA - Specifications and Querydsl</a>
*/
public class UserSpecifications {
public static Specification<User> likeTown(String town) {
return new Specification<User>() {
@Override
public Predicate toPredicate(Root<User> root, CriteriaQuery<?> query, CriteriaBuilder cb) {
return cb.like(cb.lower(root.get("billingAddress").get("town")), '%' + StringUtils.lowerCase(town) + '%');
}
};
}
使用这个“规范”如下:
List<User> users = userRepository.findAll(UserSpecifications.likeTown(myTown));
但现在,我还想在城镇中搜索可能不存在的 shippingAddress。
我尝试在cb.or 中结合cb.like,但结果是生成的SQL 查询有一个用于shippingAddress 的INNER JOIN,这是不正确的,因为如上所述,它可能为null,所以我想要一个LEFT JOIN .
怎么做?
谢谢。
【问题讨论】:
标签: java spring-data-jpa spring-data jpa-2.0 specifications