簡介
物件映射中的雙向關係通常需要仔細處理以避免資料庫不一致。 Hibernate 提供了一種簡潔的語法,mappedBy,來建立這些關係。本文解釋了JPA和Hibernate中mappedBy的用途和用法。
什麼是mappedBy?
MappedBy指定擁有者實體的主鍵儲存在所屬表中的欄位。它允許您映射雙向關係,其中只有一個表具有另一個表的外鍵。這可以確保所有者實體擁有關係的所有權並避免循環關係。
mappedBy
MappedBy 的目的解決了避免重複外鍵約束的問題雙向關係。透過將一張表指定為擁有者,並將其主鍵儲存在另一張表中,可以保證資料一致性。
用法
要使用mappedBy,需要註解具有mappedBy 屬性的子實體中的@JoinColumn 或@JoinTable。此屬性採用擁有者實體中表示關係的屬性的名稱。
範例
考慮查詢中提供的範例:
<code class="java">@OneToMany(fetch=FetchType.LAZY, cascade = {CascadeType.ALL}) @JoinColumn(name="IDAIRLINE") public Set<AirlineFlight> getAirlineFlights() { return airlineFlights; }</code>
@JoinColumn 註解將外鍵限制指派給AirlineFlight 資料表中的。但是,缺少mappedBy屬性。
要讓Airline成為關係的擁有者,我們可以修改註解如下:
<code class="java">@OneToMany(fetch=FetchType.LAZY, cascade = {CascadeType.ALL}) @JoinColumn(name="IDAIRLINE", mappedBy="airline") public Set<AirlineFlight> getAirlineFlights() { return airlineFlights; }</code>
透過新增mappedBy="airline",我們表示AirlineFlight 表中的IDAIRLINE 欄位是航空公司實體的主鍵。這建立了一種雙向關係,航空公司擁有 AirlineFlight 實例,而無需在航空公司表中使用重複的外鍵。
以上是JPA 和 Hibernate 中的「mappedBy」屬性如何協助管理雙向關係?的詳細內容。更多資訊請關注PHP中文網其他相關文章!