一對(duì)一外鍵雙向關(guān)聯(lián)
注:一對(duì)一外鍵雙向關(guān)聯(lián)是一對(duì)多外鍵關(guān)聯(lián)的特例,只是在多的一方加了一個(gè)唯一性約束谣膳。
USERS1表->用戶表
????USERID number(6) <pk>
????USERNAME nvarchar2(20)
????USERPASS nvarchar2(20)
RESUME1表->檔案表
????RESID number(6) <pk>
????RESUSERID number(6) <fk>
????RESNAME nvarcahr2(20)
????RESCARDNO nvarcahr2(20)
以上RESUME1表的RESUSERID外鍵設(shè)為了unique約束赋焕,確保每條RESUME1記錄具有唯一的RESUSERID参歹。
因?yàn)樵趶谋?檔案表)添加了唯一約束隆判,所以我們可以看出一個(gè)用戶對(duì)應(yīng)一個(gè)檔案僧界,一個(gè)檔案對(duì)應(yīng)一個(gè)用戶。
對(duì)應(yīng)持久化類
Users1
????userid : Integer
????username : String
????userpwass : String
????resume1 : Resume1
Resume1
????resid : Integer
????users1 : Users1
????resname : String
????rescardno : String
映射配置文件 Users1.hbm.xml配置
<one-to-one name="resume1" class="包.Resume1"/>
Resume1.hbm.xml配置
<many-to-one name="users1"class="包.Users1"column="RESUSERID"unique="true"/> ```
這句代碼的意思是用column屬性的值捂襟,到class類中去找,找到后保存到name值的屬性中陪每。Unique屬性一般設(shè)置在從表。注:配置好了這兩個(gè)文件之后侨核,[hibernate](http://lib.csdn.net/base/javaee)會(huì)根據(jù)這兩個(gè)文件來(lái)找到相對(duì)應(yīng)的數(shù)據(jù)犁钟。
## 一對(duì)一主鍵雙向關(guān)聯(lián)
USERS1表->用戶表
USERID number(6) <pk,fk>
USERNAME nvarchar2(20)
USERPASS nvarchar2(20)
RESUME1表->檔案表
RESID number(6) <pk>
RESNAME nvarcahr2(20)
RESCARDNO nvarcahr2(20)
對(duì)應(yīng)持久化類
Users1
userid : Integer
username : String
userpwass : String
resume1 : Resume1
Resume1
resid : Integer
users1 : Users1
resname : String
rescardno : String
映射配置文件
Users1.hbm.xml配置
<one-to-one name=”Resume1” class=”包.Resume1”constrained=”true”/>
constrained屬性表明,將Users1類的主鍵看成外鍵魁索,本屬性一般設(shè)置在從表。
Resume1.hbm.xml配置
<one-to-one name=” users1” class=”包.Users1”/>
注:配置好了這兩個(gè)文件之后粗蔚,Hibernate會(huì)根據(jù)這兩個(gè)文件來(lái)找到相對(duì)應(yīng)的數(shù)據(jù)饶火。
![](http://upload-images.jianshu.io/upload_images/3938475-36a8bb972c889086.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)