日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) >

java hibernate 表关联_Hibernate多表关联

發(fā)布時(shí)間:2025/3/11 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java hibernate 表关联_Hibernate多表关联 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

一、多對(duì)一進(jìn)行關(guān)聯(lián)(多個(gè)學(xué)生對(duì)應(yīng)同一間宿舍)---學(xué)生是主體,宿舍是附體,關(guān)聯(lián)關(guān)系在主體學(xué)生中設(shè)置,在學(xué)生類中設(shè)置宿舍類,由于宿舍類只有一個(gè)可以直接用類來(lái)設(shè)置,在映射學(xué)生類(User)中包含宿舍這個(gè)類(Room),在映射配置文件(User.hbm.xml)中定義

哪個(gè)是主體類就在哪個(gè)配置文件定義關(guān)聯(lián)關(guān)系.

cascade屬性:表示關(guān)聯(lián)對(duì)象的持久化,該屬性也要設(shè)置在主體中,作用就是當(dāng)主控方執(zhí)行操作時(shí),關(guān)聯(lián)對(duì)象(被動(dòng)方)是否同步執(zhí)行同一操作.

cascade的值:all:表示所有情況下都進(jìn)行級(jí)聯(lián)操作.

none:所有情況下都不進(jìn)行級(jí)聯(lián)操作

save-update:在執(zhí)行save-update時(shí)進(jìn)行級(jí)聯(lián)操作.

delete:在執(zhí)行delete時(shí)進(jìn)行級(jí)聯(lián)操作.

注意:使用cascade自動(dòng)持久化時(shí),會(huì)先檢查被關(guān)聯(lián)物件的id屬性,未被持久化的物件之id屬性是由unsaved-value決定,預(yù)設(shè)是null,如果您使用long這樣的原生型態(tài)(primitive type)時(shí),則必須自行指定預(yù)設(shè)值.

例如:

如果您不想額外設(shè)定unsaved-value資訊,則可以將long改為L(zhǎng)ong,這可以符合預(yù)設(shè)的unsaved-value為null的設(shè)定?.

二、一對(duì)多進(jìn)行關(guān)聯(lián)(一間宿舍對(duì)應(yīng)多個(gè)學(xué)生)---宿舍是主體,學(xué)生是附體,關(guān)聯(lián)關(guān)系在主體宿舍中設(shè)置,由于要在宿舍類中設(shè)置學(xué)生類,一個(gè)宿舍包含多個(gè)學(xué)生,所以在宿舍類中要用Set類來(lái)進(jìn)行設(shè)置,用set類(private Set users = new HashSet();)來(lái)存儲(chǔ)多個(gè)學(xué)生類,在映射宿舍類(Room)中要包含這個(gè)節(jié)點(diǎn),用來(lái)與user相關(guān)聯(lián)

例如:

name:表示屬性,table:表示關(guān)聯(lián)的表名,key:表示通過(guò)什么字段進(jìn)行關(guān)聯(lián),:表示關(guān)聯(lián)類。這里也可以使用cascade屬性。

三、在表關(guān)聯(lián)的設(shè)計(jì)中,不論是一對(duì)多還是多對(duì)一,都要將關(guān)聯(lián)字段設(shè)置在多的那一方。

例如:user表格和room表格,要將關(guān)聯(lián)字段room_id設(shè)置在user表格中。

四、一對(duì)一進(jìn)行關(guān)聯(lián)(一個(gè)人只有一個(gè)房間,一個(gè)房間也只有一個(gè)人)。

可以通過(guò)2中方式進(jìn)行關(guān)聯(lián):

(1)、通過(guò)外鍵進(jìn)行關(guān)聯(lián):在多對(duì)一的例子中就是通過(guò)外鍵進(jìn)行關(guān)聯(lián)的.

在user-room的設(shè)置中(user.hbm.xml):

column="ROOM_ID"

class="onlyfun.caterpillar.Room"

cascade="all"

unique="true"/>

其中unique表示限制一個(gè)User有一獨(dú)有的 Room,這只是單向的,說(shuō)明一個(gè)user只有一個(gè)room.

在room-user的設(shè)置中(room.hbm.xml):

class="onlyfun.caterpillar.User"

property-ref="room"/>

這樣就完成了雙向的一對(duì)一關(guān)聯(lián),property-ref告訴hibernate,查詢出user并將其參考至room。

(2)、通過(guò)主鍵進(jìn)行關(guān)聯(lián):限制兩個(gè)資料表的主鍵使用相同的值,如此一個(gè)User與Room就是一對(duì)一關(guān)係

user.hbm.xml:

class="onlyfun.caterpillar.Room"

cascade="all"/>

room.hbm.xml:

class="onlyfun.caterpillar.User"

constrained="true"/>

使用constrained="true"告訴Hibernate參考至User的主鍵

五、雙向關(guān)聯(lián),就是將一和二結(jié)合起來(lái),如果將關(guān)聯(lián)的維護(hù)交給User的話會(huì)比較容易,因?yàn)槊總€(gè)User都對(duì)應(yīng)至一個(gè)Room,在儲(chǔ)存時(shí)並用像Room一樣必須對(duì)Set中的每個(gè)物件作檢查,為了將關(guān)聯(lián)的維護(hù)交給User,我們可以在Room.hbm.xml中的修改,加上inverse="true",表示將關(guān)聯(lián)的維護(hù)「反過(guò)來(lái)」交給User作例如:?????????????

在設(shè)立雙向關(guān)聯(lián)時(shí),關(guān)聯(lián)由多對(duì)一中「多」的哪一方維護(hù),會(huì)比由「一」的哪一方維護(hù)來(lái)的方便,在Hibernate可以藉由inverse來(lái)設(shè)定,不設(shè)定inverse基本上也可以運(yùn)行,但是效能會(huì)較差

總結(jié)

以上是生活随笔為你收集整理的java hibernate 表关联_Hibernate多表关联的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。