JPA / Hibernate:双向OneToMany / ManyToOne关系仅适用于单向

时间:2013-06-05 10:40:41

标签: java hibernate java-ee jpa

我目前遇到OneToMany / ManyToOne-Mapping问题。映射看起来像这样:

public class A implements Serializable {
    @EmbeddedId
    private AId id;

    // Other stuff...
}

@Embeddable
public class AId implements Serializable {
    @ManyToOne
    @JoinColumn(name = "B_ID", nullable = false)
    private B b;

    // Other stuff...
}

public class B implements Serializable {
    @OneToMany(mappedBy = "id.b")
    private List<A> as;

    // Other stuff...
}

如果我尝试使用对象A访问对象B,一切正常,但反方向根本不起作用。关系始终为空。

A objectA = findAById(id);
B objectB = objectA.getB(); // OK

// But... for example
objectB.getAs(); // returns null

我写了一个小查询来使用主键获取对象B的所有As:

SELECT as FROM B b, IN(b.as) as WHERE b.id = :id

这很有效,我得到了预期的结果。 我也检查了数据库中存在的内容,并且没问题。有没有人知道为什么这种关系只能在一个方向上起作用?

此致

亚历

1 个答案:

答案 0 :(得分:1)

那是因为默认情况下@onetomany有懒惰的提取。您可以使用此方法解决此问题 fetch = FetchType.EAGER

public class B implements Serializable {
    @OneToMany(mappedBy = "id.b", fetch = FetchType.EAGER)
    private List<A> as;

    // Other stuff...
}