java - hibernate 条件 : find entity if any of its children's children have a specific property

标签 java hibernate hql criteria

我需要编写一个条件(或 hql)来通过其子实体的子实体的属性查找父实体。这是我的实体:

// The top level parent class
public class A {
    private Long id;
    private String someProperty;
    private B b;
    // and some other attributes...
}

// The second level parent class :)
public class B {
    private Long id;
    private List<C> cList;
    // and some other attributes...
}

public class C {
    private Long id;
    private B b;
    private List<D> dList;
    // Other attributes..
}

public class D {
    private Long id;
    private C c;
    private String importantAttribute;
    // Other attributes..
}

问题如下。如果任何 D 记录具有条件 importantAttribute=="something"并且 A 具有条件 someProperty=="somethingelse",我想获取 A 记录的列表。

如何为此编写 hibernate 标准?到目前为止,我只能写下以下内容:

Criteria criteria = getSession().createCriteria(A.class, "a");
criteria.add(Restrictions.eq("a.someProperty", "somethingelse");

DetachedCriteria sub = DetachedCriteria.forClass(D.class, "d");
sub.add(Restrictions.eq("d.importantAttribute", "something"));
sub.setProjection(Projections.property("id"));

然后我放弃了。

最佳答案

试试这个

Criteria criteria = getSession().createCriteria(A.class, "a");
criteria.createAlias("a.b", "b");
criteria.createAlias("b.cList", "c");
criteria.createAlias("c.dList", "d");
criteria.add(Restrictions.eq("a.someProperty", "somethingelse");
criteria.add(Restrictions.eq("d.importantAttribute", "something");

关于java - hibernate 条件 : find entity if any of its children's children have a specific property,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29436261/

相关文章:

java - ruby 在 Netty 中为 LengthFieldBasedFrameDecoder 参数构建一个文件

java - spring boot jpa无法创建表

grails - 使用条件,如何在Grails GORM中基于max(column)获取结果列表

java - springdoc-openapi 不同的例子

java - Intellij 中的调用树

mysql - 如何获取行组的最大日期

hibernate - 如果没有更新完成,LockMode.WRITE是否释放锁

sql - 在 HQL 中指定索引提示

hadoop - 如何使用另一个表中的特定列值在 Hive 中创建表

java - 如何用 JSF 实现 JQuery 确认对话框