首頁 >Java >java教程 >JPA:@JoinColumn 與mappedBy:何時使用哪一個?

JPA:@JoinColumn 與mappedBy:何時使用哪一個?

DDD
DDD原創
2024-12-15 22:39:24863瀏覽

JPA: @JoinColumn vs. mappedBy: When to Use Which?

了解JPA JoinColumn 與mappedBy

在JPA 中,@JoinColumn 註解定義目前實體中所引用列的外鍵列引用的實體。相較之下,mappedBy 屬性指定目前實體是雙向關係的反向關係,其中外鍵的所有權位於引用的實體中。

所有權和反向關係

使用@JoinColumn時,帶有註釋的實體被視為關係的「所有者」。因此,其表將包含連結到引用表的外鍵列。另一方面,mappedBy 屬性表示帶有此註解的實體是關係的「反」方。外鍵的所有權位於mappedBy所引用的實體。

註解範例

以下是一個說明差異的範例:

@Entity
public class Company {

    @OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY)
    @JoinColumn(name = "companyIdRef", referencedColumnName = "companyId")
    private List<Branch> branches;
    ...
}

@Entity
public class Company {

    @OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY, mappedBy = "companyIdRef")
    private List<Branch> branches;
    ...
}

在第一個程式碼區塊中,使用了@JoinColumn,使Company成為關係的擁有者。 Company 的表將包含引用 Branch 表中的「companyId」列的外鍵列「companyIdRef」。

在第二個程式碼區塊中,使用mappedBy,使 Company 成為關係的反面。 Branch 現在是擁有者,其表將包含引用 Company 的「companyId」列的外鍵列「companyIdRef」。

雙向關係

使用mappedBy 時,您可以從關係的任一側存取相關實體,從而實現雙向導航。單獨使用 @JoinColumn 時這是不可能的,因為外鍵所有權僅屬於一個實體。

以上是JPA:@JoinColumn 與mappedBy:何時使用哪一個?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn