6

我使用 EclipseLink 作为 JPA 提供程序。此外,我正在使用以下 TABLE_PER_CLASS 继承结构

@javax.persistence.Entity
@Inheritance(strategy = InheritanceType.TABLE_PER_CLASS)
@NamedQueries({
    @NamedQuery(name=Parent.QUERY_FIND_ALL, query="SELECT p FROM Parent p")
})
public class Parent {
        // the class code follows here
}

@javax.persistence.Entity 
@NamedQueries({
    @NamedQuery(name=Child.QUERY_FIND_ALL, query="SELECT c FROM Child c")
})

public class Child extends Parent {
        // the class code follows here
}

现在的问题是我只想接收父类的条目。但是使用命名查询“SELECT p FROM Parent p”也会返回子表中的所有条目。

选择或查找代码如下:

public List findWithNamedQuery(String query) {
        return em.createNamedQuery(query).getResultList();
}

因此查询即“SELECT p FROM Parent p”。

我怎样才能只收到真正的父条目而不是这个继承层次结构的所有条目?

简而言之:如何保持所有子条目不变,只返回父条目?

编辑 1:
我使用的是 EclipseLink 2.0.1,但每次我通过类型表达式尝试 axtavt 的解决方案时,都会收到以下错误:

"Invalid Type Expression on [my.domain.Parent].  The class does not have a descriptor, or a descriptor that does not use inheritance or uses a ClassExctractor for inheritance".

我也更新到 EclipseLink 的最新稳定版本 2.1.1,但它并没有解决问题。

4

2 回答 2

8

如果您的 EclipseLink 版本支持 JPA 2.0,您可以编写

SELECT p FROM Parent p WHERE TYPE(p) = Parent
于 2010-11-23T13:26:03.730 回答
4

结合 TABLE_PER_CLASS 继承的 Type 表达式在 EclipseLink 2.1.1 下不起作用,这似乎是一个错误。

另请参阅JPA 2.0 的答案:TYPE 表达式异常

于 2010-12-02T14:19:07.680 回答