JPA:“JoinColumn”和“PrimaryKeyJoinColumn”的区别?

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (1)
  • 关注 (0)
  • 查看 (1733)

@JoinColumn@PrimaryKeyJoinColumn到底有什么区别?

你用@JoinColumn对于作为外键一部分的列。典型的列可能看起来类似于(例如,在具有附加属性的联接表中):

@ManyToOne
@JoinColumn(name = "...")
private OtherClass oc;

如果我也将列提升为a/pk(也就是标识关系),会发生什么情况?由于列现在是pk,所以我必须用@Id:

@Id
@ManyToOne
@JoinColumn(name = "...")
private OtherClass oc;

现在的问题是:

@Id+@JoinColumn同.@PrimaryKeyJoinColumn?:

@ManyToOne
@PrimaryKeyJoinColumn(name = "...")
private OtherClass oc;

如果不是,什么是@PrimaryKeyJoinColumn

提问于
用户回答回答于

如果我也推动专栏成为PK(也称为识别关系),会发生什么?由于列现在是PK,我必须用@Id(...)标记它。

派生标识符的这种增强支持实际上是JPA 2.0中新内容的一部分(请参阅2.4.1与JPA 2.0规范中的派生标识相对应的主键),JPA 1.0不允许Id使用a OneToOneManyToOne。使用JPA 1.0,你必须使用PrimaryKeyJoinColumn并定义Basic Id外键列的映射。

现在的问题是:@Id + @JoinColumn与@PrimaryKeyJoinColumn相同吗?

可以得到类似的结果,但使用IdOneToOneManyToOne简单得多,并且是衍生识别符与JPA 2.0映射的首选方式。PrimaryKeyJoinColumn可能仍然用于JOINED继承策略。在JPA 2.0规范的相关部分下方:

11.1.40 PrimaryKeyJoinColumn标注 该PrimaryKeyJoinColumn注释指定一个主键列,该列用作外键以连接到另一个表。 的PrimaryKeyJoinColumn注释用于连接在一个实体子类的主表JOINED 映射策略到它的父类的主表; 它在 SecondaryTable注释中用于将辅助表连接到主表; 并且它可以用在一个OneToOne 映射中,在该映射中引用实体的主键被用作引用实体的外键[108]。 ... 如果PrimaryKeyJoinColumn 在JOINED映射策略中没有为子类指定注释,则假定外键列的名称与超类主表的主键列相同。 ... 示例: Customer和ValuedCustomer子类 @Entity @Table(name="CUST") @Inheritance(strategy=JOINED) @DiscriminatorValue("CUST") public class Customer { ... } @Entity @Table(name="VCUST") @DiscriminatorValue("VCUST") @PrimaryKeyJoinColumn(name="CUST_ID") public class ValuedCustomer extends Customer { ... } [108] 2.4.1.1节中描述的派生ID机制现在优于 PrimaryKeyJoinColumnOneToOne映射案例。

扫码关注云+社区

领取腾讯云代金券