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

标签 java hibernate foreign-keys hibernate-mapping

假设提供了以下映射:

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

相关文章:

java - Elasticsearch Java 客户端 SearchResponse 无法识别聚合/存储桶

java - 类型不适用,我找不到错误

java - 问题从类返回值

java - 如何知道是什么让 hibernate 持久化对象变脏了?

spring - 从 Spring Boot 应用程序访问 SessionFactory

c# - 获取 C# 中链接的外键表的值

Java 多线程 - 有没有办法同步/锁定映射中的特定值以进行读取和写入?

java - 如何启用 Weblogic 12.1.2 JPA 2.1

sql - 外键约束是否自动禁止空值?

python - 基于跨关系的查找将选择限制为外键