89

@JoinColumn和之间的确切区别是@PrimaryKeyJoinColumn什么?

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

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

如果我也将列提升为 PK(也称为识别关系),会发生什么情况?由于该列现在是 PK,因此我必须将其标记为@Id

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

现在的问题是:

@Id+@JoinColumn和刚才一样吗@PrimaryKeyJoinColumn?:

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

如果不是,那@PrimaryKeyJoinColumn有什么用?

4

3 回答 3

56

如果我也将列提升为 PK(也称为识别关系),会发生什么情况?由于该列现在是 PK,因此我必须使用 @Id (...) 对其进行标记。

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

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

您可以获得类似的结果,但使用Idon OneToOneorManyToOne简单,并且是使用 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 机制现在将优先 PrimaryKeyJoinColumn于 OneToOne 映射情况。

也可以看看


此来源http://weblogs.java.net/blog/felipegaucho/archive/2009/10/24/jpa-join-table-additional-state指出使用 @ManyToOne 和 @Id 可用于 JPA 1.x。现在谁是对的?

作者正在使用 EclipseLink 的预发布JPA 2.0兼容版本(本文发表时版本为2.0.0-M7)来写一篇关于 JPA 1.0(!)的文章。这篇文章具有误导性,作者使用的东西不是JPA 1.0 的一部分。

作为记录,EclipseLink 1.1中添加IdonOneToOne和 但让我坚持,这不是JPA 1.0 的一部分。ManyToOne

于 2010-08-05T20:43:18.693 回答
45

我通常通过这张图区分这两者:

利用PrimaryKeyJoinColumn

在此处输入图像描述

利用JoinColumn

在此处输入图像描述

于 2018-02-14T03:29:57.843 回答
2

PrimaryKeyColumn我知道这是一篇旧帖子,但如果您想要单向关系或有多个表都共享相同的 ID,那么使用它的好时机。

一般来说,这是一个坏主意,最好将外键关系与JoinColumn.

话虽如此,如果您正在使用像这样的系统的旧数据库,那么这将是使用它的好时机。

于 2019-08-28T15:54:09.940 回答