gpt4 book ai didi

java - 是否可以在没有对象到对象映射的情况下强制执行外键?

转载 作者:塔克拉玛干 更新时间:2023-11-03 04:48:12 27 4
gpt4 key购买 nike

假设提供了以下映射:

<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/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com