критерии hibernate/jpa, запрос, существует ли объект в отношении многие ко многим

У меня есть класс Offer с отношением "многие ко многим" department:

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, которые содержат определенный department (NamedCode).

Это должно быть частью большего запроса (см. часть 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")));

person flavio.donze    schedule 22.09.2016    source источник
comment
может быть, присоединиться к Департаменту, а затем поставить ограничение на Департамент?   -  person Neil Stockton    schedule 22.09.2016


Ответы (1)


Я понял, мне все-таки нужно использовать соединение:

restrictions.add(builder.equal(root.join("department").get("id"), department.getId()));
person flavio.donze    schedule 23.09.2016
comment
что, если я хочу проверить, существует ли какой-либо отдел для каждого предложения. Предположим, мне нужны все предложения с определенным отделом и все предложения без отдела. @flavio.donze - person RezKesh; 23.06.2018