Hibernate延迟加载在OneToOne关系中不起作用

时间:2015-06-08 20:56:06

标签: hibernate java-ee

在我的公司,我们将一个旧应用程序从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一切正常并且没有注释?

3 个答案:

答案 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