溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Hibernate中cascade和inverse怎么用

發(fā)布時(shí)間:2021-12-03 09:52:14 來源:億速云 閱讀:105 作者:小新 欄目:編程語言

這篇文章主要為大家展示了“Hibernate中cascade和inverse怎么用”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“Hibernate中cascade和inverse怎么用”這篇文章吧。

1、到底在哪用cascade="..."?

Hibernate中cascade屬性并不是多對(duì)多關(guān)系一定要用的,有了它只是讓我們?cè)诓迦牖騽h除對(duì)像時(shí)更方便一些,只要在cascade的源頭上插入或是刪除,所有 cascade的關(guān)系就會(huì)被自己動(dòng)的插入或是刪除。便是為了能正確的cascade,unsaved-value是個(gè)很重要的屬性。Hibernate通 過這個(gè)屬性來判斷一個(gè)對(duì)象應(yīng)該save還是update,如果這個(gè)對(duì)象的id是unsaved-value的話,那說明這個(gè)對(duì)象不是 persistence object要save(insert);如果id是非unsaved-value的話,那說明這個(gè)對(duì)象是persistence object(數(shù)據(jù)庫中已存在),只要update就行了。saveOrUpdate方法用的也是這個(gè)機(jī)制。

2、到底在哪用inverse="ture"?

“set的inverse屬性決定是否把對(duì)set的改動(dòng)反映到數(shù)據(jù)庫中去。inverse=false————反映;inverse=true————不反映”inverse屬性默認(rèn)為false

Hibernate中inverse屬性默認(rèn)是false的,就是說關(guān)系的兩端都來維護(hù)關(guān)系。這個(gè)意思就是說,如有一個(gè)Student, Teacher和TeacherStudent表,Student和Teacher是多對(duì)多對(duì)多關(guān)系,這個(gè)關(guān)系由TeacherStudent這個(gè)表來表 現(xiàn)。那么什么時(shí)候插入或刪除TeacherStudent表中的記錄來維護(hù)關(guān)系呢?在用hibernate時(shí),我們不會(huì)顯示的對(duì) TeacherStudent表做操作。對(duì)TeacherStudent的操作是hibernate幫我們做的。hibernate就是看hbm文件中指 定的是"誰"維護(hù)關(guān)系,那個(gè)在插入或刪除"誰"時(shí),就會(huì)處發(fā)對(duì)關(guān)系表的操作。前提是"誰"這個(gè)對(duì)象已經(jīng)知道這個(gè)關(guān)系了,就是說關(guān)系另一頭的對(duì)象已經(jīng)set 或是add到"誰"這個(gè)對(duì)象里來了。前面說過inverse默認(rèn)是false,就是關(guān)系的兩端都維護(hù)關(guān)系,對(duì)其中任一個(gè)操作都會(huì)處發(fā)對(duì)表系表的操作。當(dāng)在 關(guān)系的一頭,如Student中的bag或set中用了inverse="true"時(shí),那就代表關(guān)系是由另一關(guān)維護(hù)的(Teacher)。就是說當(dāng)這插 入Student時(shí),不會(huì)操作TeacherStudent表,即使Student已經(jīng)知道了關(guān)系。只有當(dāng)Teacher插入或刪除時(shí)才會(huì)處發(fā)對(duì)關(guān)系表的 操作。所以,當(dāng)關(guān)系的兩頭都用inverse="true"是不對(duì)的,就會(huì)導(dǎo)致任何操作都不處發(fā)對(duì)關(guān)系表的操作。當(dāng)兩端都是inverse= "false"或是default值是,在代碼對(duì)關(guān)系顯示的維護(hù)也是不對(duì)的,會(huì)導(dǎo)致在關(guān)系表中插入兩次關(guān)系。

在一對(duì)多關(guān)系中inverse就更有意義了。在多對(duì)多中,在哪端inverse="true"效果差不多(在效率上)。但是在一對(duì)多中,如果要一方維護(hù)關(guān) 系,就會(huì)使在插入或是刪除"一"方時(shí)去update"多"方的每一個(gè)與這個(gè)"一"的對(duì)象有關(guān)系的對(duì)象。而如果讓"多"方面維護(hù)關(guān)系時(shí)就不會(huì)有update 操作,因?yàn)殛P(guān)系就是在多方的對(duì)象中的,直指插入或是刪除多方對(duì)象就行了。當(dāng)然這時(shí)也要遍歷"多"方的每一個(gè)對(duì)象顯示的操作修關(guān)系的變化體現(xiàn)到DB中。不管 怎樣說,還是讓"多"方維護(hù)關(guān)系更直觀一些。

(1)對(duì)one-to-many而言,改變set,會(huì)讓hibernate執(zhí)行一系列的update語句, 不會(huì)delete/insert數(shù)據(jù)

(2)對(duì)many-to-many而言,改變set,只修改關(guān)系表的數(shù)據(jù),不會(huì)影響many-to-many的另一方。

(3)雖然one-to-many和many-to-many的數(shù)據(jù)庫操作不一樣,但目的都是一個(gè):維護(hù)數(shù)據(jù)的一致性。

3、cascade和inverse有什么區(qū)別?

可以這樣理解,cascade定義的是關(guān)系兩端對(duì)象到對(duì)象的級(jí)聯(lián)關(guān)系;而inverse定義的是關(guān)系和對(duì)象的級(jí)聯(lián)關(guān)系。

Hibernate的inverse只對(duì)set+one-to-many(或many-to-many)有效,對(duì)many-to-one, one-to-one無效。cascade對(duì)關(guān)系標(biāo)記都有效。

inverse對(duì)集合對(duì)象整體起作用,cascade對(duì)集合對(duì)象中的一個(gè)一個(gè)元素起作用,如果集合為空,那么cascade不會(huì)引發(fā)關(guān)聯(lián)操作。

比如將集合對(duì)象置為null, school.setStudentSet(null)

inverse導(dǎo)致hibernate執(zhí)行:udpate STUDENT set SCHOOL_ID=null where SCHOOL_ID=?

cascade則不會(huì)執(zhí)行對(duì)STUDENT表的關(guān)聯(lián)更新, 因?yàn)榧现袥]有元素。

再比新增一個(gè)school, session.save(school)

inverse導(dǎo)致hibernate執(zhí)行:

for( 對(duì)(school的每一個(gè)student ){

udpate STUDENT set SCHOOL_ID=? where STUDENT_ID=? //將學(xué)生的school_id改為新的school的id

}

cascade導(dǎo)致hibernate執(zhí)行:

for( 對(duì)school的每一個(gè)student ){

session.save(aStudent); //對(duì)學(xué)生執(zhí)行save操作

}

extends:如果改變集合中的部分元素(比如新增一個(gè)元素),

inverse: hibernate先判斷哪些元素改變了,對(duì)改變的元素執(zhí)行相應(yīng)的sql

cascade: 它總是對(duì)集合中的每個(gè)元素執(zhí)行關(guān)聯(lián)操作。

(在關(guān)聯(lián)操作中,hibernate會(huì)判斷操作的對(duì)象是否改變)

兩個(gè)起作用的時(shí)機(jī)不同:

cascade:在對(duì)主控方操作時(shí),級(jí)聯(lián)發(fā)生。

inverse: 在flush時(shí)(commit會(huì)自動(dòng)執(zhí)行flush),對(duì)session中的所有set,hibernate判斷每個(gè)set是否有變化,

對(duì)有變化的set執(zhí)行相應(yīng)的sql,執(zhí)行之前,會(huì)有個(gè)判斷:if( inverse == true ) return;可以看出cascade在先,inverse在后。

inverse 對(duì)set + one-to-many 和 set + many-to-many 起的作用不同。hibernate生成的sql不同。

對(duì)one-to-many,hibernate對(duì)many方的數(shù)據(jù)庫表執(zhí)行update語句。

對(duì)many-to-many, hibernate對(duì)關(guān)系表執(zhí)行insert/update/delte語句,注意不是對(duì)many方的數(shù)據(jù)庫表而是關(guān)系表。

cascase 對(duì)set都是一致的,不管one-to-many還是many-to-many。都簡(jiǎn)單地把操作傳遞到set中的每個(gè)元素。所以它總是更新many方的數(shù)據(jù)庫表。

4、Hibernate中cascade和inverse有什么相同?

這兩個(gè)屬性本身互不影響,但起的作用有些類似,都能引發(fā)對(duì)關(guān)系表的更新。

5、 建議:只對(duì)set + many-to-many設(shè)置inverse=false,其他的標(biāo)記不考慮inverse屬性,都設(shè)為inverse=true。對(duì)cascade,一 般對(duì)many-to-one,many-to-many,constrained=true的one-to-one 不設(shè)置級(jí)聯(lián)刪除。

以上是“Hibernate中cascade和inverse怎么用”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI