我目前遇到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
这很有效,我得到了预期的结果。 我也检查了数据库中存在的内容,并且没问题。有没有人知道为什么这种关系只能在一个方向上起作用?
此致
亚历
答案 0 :(得分:1)
那是因为默认情况下@onetomany有懒惰的提取。您可以使用此方法解决此问题 fetch = FetchType.EAGER
public class B implements Serializable {
@OneToMany(mappedBy = "id.b", fetch = FetchType.EAGER)
private List<A> as;
// Other stuff...
}