了解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中文網其他相關文章!