假设提供了以下映射:
<class name="A" table="a_table">
<id name="id"/>
<many-to-one name="entityB" column="fk_B" not-null="false" unique="true"/>
</class>
<class name="B" table="b_table">
<id name="id"/>
</class>
Java 类:
public class A {
private long id;
private B entityB;
// getters and setters skipped
}
是否可以更改 Hibernate 映射,以便 Hibernate 在启动时仍然强制执行和创建外键,但是类 A
看起来像下面这样:
public class A {
private long id;
private long idOfB;
// getters and setters skipped
}
我明白如果我转换 <many-to-one...
进入 <property...
这可行,但数据库不会强制执行外键。
我需要这样做,因为对象 B
可能(或可能不会)单独初始化,这有时会导致
org.hibernate.LazyInitializationException: could not initialize proxy - no Session
a.getB()
时发生异常叫做。我宁愿把它作为 long idOfB
并在必要时加载整个对象;这也会使对象加载 A
更快。
我相信我的问题与 this one 非常相似,但提供的解决方案(使用延迟加载)并不适合我的情况,即使我调用 a.getB().getId()
, 我会得到 LazyInitializationException
而如果我调用 a.getIdOfB()
我不会。
非常感谢。
最佳答案
如前所述
I understand that if I convert <many-to-one... into a <property... this would work, but foreign key would not be enforced by the database.
所以我的建议是:同时使用
public class EntityA {
private Integer idOfB;
private EntityB entityB;
// getter's and setter's
}
和
<class name="A" table="a_table">
<id name="id"/>
<property name="idOfB" column="fk_B" not-null="false" unique="true"/>
<many-to-one name="entityB" update="false" insert="false" column="fk_B"/>
</class>
请注意,当两个属性共享同一列时,您必须将有关它的设置放在一个属性中。否则,Hibernate 会提示一些错误。它解释了为什么我在 entityB 属性中定义 update="false"和 insert="false"。
问候,
关于java - 是否可以在没有对象到对象映射的情况下强制执行外键?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2111294/