Hibernate一對一雙向關聯(外鍵)

網站上各類搜索,都是一些清晰或者不清晰的例子,可是用下來一是確實不給力,二是徹底不知道因此然。java

後來終於在書中查到了就在這裏記一下。fetch

首先要說明,這裏只解釋雙向一對一隻有一個表裏面有外鍵的狀況。網站

就以比較廣泛的Person和Address爲例。spa

新建表t_person: person_id,person_name.code

新建表t_address:address_id,person_id.xml

新建Person.java類裏面有屬性:personId, personName, address;blog

新建Address.java類裏面有屬性:addressId,person;class

重點來了,在Person.hbm.xml裏面這麼配置配置

<one-to-one name="address" class="com.bean.Address" cascade="all" property-ref="person"/>

而在Address.hbm.xml裏面這麼配置select

<many-to-one name="person" class="com.bean.Person" fetch="select" unique="true" column="person_id"/>

咱們能夠看到一個是one-to-one一個是many-to-one的unique。

分清楚這兩個很重要,many-to-one用在保存外鍵的表,也就是說Address表,one-to-one用在沒有保存外鍵的表,也就是person表.

而Address.hbm.xml這個配置的意思是:在Address.java裏面有一個person屬性,它是一個外鍵,而且對應的列是t_address表裏面的person_id. unique="true" 是說這裏的關係是一對一的。

Person.hbm.xml 的配置文件意思是:我是一個主表,我裏面有一個addresss的屬性,跟t_address表裏面的person_id是關聯再一塊兒 的。

cascade=「all」的意思是,級聯全部操做,關於這個屬性更詳細的資料本身查去。

這樣就夠清楚了吧。

相關文章
相關標籤/搜索