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


網站上各種搜索,都是一些清晰或者不清晰的例子,但是用下來一是確實不給力,二是完全不知道所以然。

后來終於在書中查到了就在這里記一下。

首先要說明,這里只解釋雙向一對一只有一個表里面有外鍵的情況。

就以比較普遍的Person和Address為例。

新建表t_person: person_id,person_name.

新建表t_address:address_id,person_id.

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

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

重點來了,在Person.hbm.xml里面這么配置

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

而在Address.hbm.xml里面這么配置

<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”的意思是,級聯所有操作,關於這個屬性更詳細的資料自己查去。

這樣就夠清楚了吧。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM