繁体   English   中英

休眠/ jpa条件,查询对象是否存在多对多关系

[英]hibernate/jpa criteria, query if an object exists in a many to many relation

我有一个与许多关系department Offer的课程Offer

class Offer {

    @ManyToMany(fetch = FetchType.EAGER, cascade = { CascadeType.MERGE, CascadeType.REFRESH })
    @JoinTable(name = "Offer_Department", joinColumns = @JoinColumn(name = "offer_id"), inverseJoinColumns = @JoinColumn(name = "namecode_id"))
    private Set<NamedCode> department;

    ...
}

我如何使用JPA CriteriaBuilder搜索所有Offer包含一个特定对象departmentNamedCode )。

这应该是更大查询的一部分(请参阅TODO部分):

CriteriaBuilder builder = getSession().getCriteriaBuilder();
CriteriaQuery<Offer> criteria = builder.createQuery(Offer.class);
Root<Offer> root = criteria.from(Offer.class);

List<Predicate> restrictions = new ArrayList<>();
if (fromDate != null && toDate != null) {
    restrictions.add(builder.between(root.get("entryDate"), fromDate, toDate));
}
if (department != null) {
    // TODO check if the Offer object has assigned the passed department
}
// add more restrictions

criteria.orderBy(builder.asc(root.get("entryDate")));

我想通了,毕竟我必须使用联接:

restrictions.add(builder.equal(root.join("department").get("id"), department.getId()));

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM