在我的公司,我们将一个旧应用程序从Hibernate 2迁移到Hibernate 4。 我的任务是将所有xml实体移动到注释。移动它后,OneToOne关系中的延迟加载停止工作。
entity a xml:
<id name="entityAid" type="integer" column="entityAid_id">
<one-to-one name="entityB" entity-name="EntityB"
property-ref="entityA" />
entity b xml:
<property name="entityAid" type="integer" column="entityA_id" />
<many-to-one name="entityA" column="entityA_id" entity-name="EntityA" update="false" insert="false" />
我用代码移动了它:
实体a
@OneToOne(fetch = FetchType.LAZY, mappedBy = "entityA")
private EntityB storageRatecard;
实体b
@ManyToOne
@JoinColumn(name = "entityA_id", insertable = false, updatable = false)
private EntityA entityA;
现在当我运行app延迟加载不起作用但在xml conf上工作。我找到了:
Making a OneToOne-relation lazy
但没有任何帮助。(我不能使用字节码检测)
我做错了什么?为什么使用xml一切正常并且没有注释?
答案 0 :(得分:2)
mi的工作是懒惰的一对一反向关系。
我读到了这个here(这也是一个很好的教程,如何使用它)。我希望它能帮助一些人,因为它可以帮助我。
答案 1 :(得分:0)
更改自:
@OneToOne(fetch = FetchType.LAZY, mappedBy = "entityA")
private EntityB storageRatecard;
到:
@OneTOMany(optional = false, fetch = FetchType.LAZY, mappedBy = "entityA")
private List<EntityB> storageRatecard;
或者,如果你想建立一对一的双向关系,而不是:
自:
@ManyToOne
@JoinColumn(name = "entityA_id", insertable = false, updatable = false)
private EntityA entityA;
为:
@OneToOne
@JoinColumn(name = "entityA_id", insertable = false, updatable = false)
private EntityA entityA;
答案 2 :(得分:0)
JPA渴望加载单端关联。有关详细信息,请查看以下链接: JPA default fetch type