java - hibernate/jpa 标准,查询对象是否存在于多对多关系中

标签 java hibernate jpa criteria hibernate-criteria

我有一个类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 搜索包含特定 department (NamedCode) 的所有 Offer 对象)。

这应该是更大查询的一部分(请参阅 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()));

关于java - hibernate/jpa 标准,查询对象是否存在于多对多关系中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39638565/

相关文章:

java - 动态表格 :select and form:option in Spring form tags

java - 无法加载 JDBC 驱动程序类 'com.postgresql.jdbc.Driver'

java - Spring boot : java. lang.IllegalArgumentException:driverClassName 需要 jdbcUrl

java - Intellij IDEA 在 jpa native 查询中显示错误

java - hibernate 5.0.1 中的编译器错误

spring - Spring数据存储库不会以多对多关系保存数据

java - 在java中使用switch case时如何从文件中获取case值?

java - 比较两个词

java - 使用 Java Bean 类的 application.properties 文件中的 Spring Boot : Reading spring. jms.jndi-name 属性

java - 具有投影的 Hibernate 条件不执行 @OneToMany 映射查询