1

我有以下层次结构

@MappedSuperclass
@Inheritance(strategy = InheritanceType.TABLE_PER_CLASS)
public abstract class Order {
...
@Entity
@Table(name = "b_order", schema = "public")
public class BOrder extends Order implements java.io.Serializable {
...
@Entity
@Table(name = "s_order", schema = "public")
public class SOrder extends Order implements java.io.Serializable {

我还有一个类,Tr 引用了两个具体的子类

@Entity
@Table(name = "tr", schema = "public")
public class Tr implements java.io.Serializable {
...
private SOrder sOrder;
private BOrder bOrder;
...
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "s_order_id", nullable = false)
public SOrder getSOrder() {
   return this.sOrder;
}
... same for BOrder

使用上面定义的类,延迟加载可以正常工作:

Tr foundTr = trDAO.findById(trId);
// test lazy loading BOrder, SOrder
BOrder foundBOrder = foundTr.getBOrder();
SOrder foundSOrder = foundTr.getSOrder();
assertNotNull(foundSOrder);
assertNotNull(foundBOrder);

但是,如果我尝试执行多态查询,它就不起作用:

public List<Order> getOrdersByUId(Long uId) {
    return (List<Order>) em.createQuery( //
        " select o from Order o " //
            + " order by o.created desc ") //
            .getResultList();

我收到一个错误:

订单未映射

基于这篇文章:http: //java.dzone.com/articles/jpa-implementation-patterns-mapping

顺便说一句,当使用 Hibernate 代理时,请注意延迟加载使用上述三种策略中的任何一种映射的类总是返回一个作为超类实例的代理。块引用

这与我看到的奇怪行为相匹配。

然而,这就是它变得奇怪的地方。如果我将父类更改为

@Entity
// @MappedSuperclass
@Inheritance(strategy = InheritanceType.TABLE_PER_CLASS)
public abstract class Order {

那就是我注释掉 MappedSuperClass 注释,多态查询有效(创建正确的联合)。问题是当我这样做时,从 Tr 到两个子类的 LAZY 加载停止工作。

有任何想法吗?我可以只使用本机查询而不是 JPA 来执行联合吗?

我正在使用 Hibernate 在 JBoss 6.0.0 中使用 JPA 2.0 - JBoss 附带的任何版本

4

1 回答 1

1

查询 MappedSuperClass 失败并没有什么奇怪的。根据 JPA 2 规范:

2.11.2 映射的超类 .... 映射的超类与实体不同,它是不可查询的,并且不能作为参数传递给 EntityManager 或 Query 操作。映射超类定义的持久关系必须是单向的。……

我在您发布的代码中填写了空白(没有@MappedSuperClass),多态查询和延迟加载似乎都适用于 Hibernate 3.5.6-Final。也许我做了一些不同的方式,缺少部分代码。你能发布更完整的例子吗?

于 2011-09-18T13:07:56.683 回答