SSH輕量級(jí)框架實(shí)踐課件:Hibernate的關(guān)聯(lián)映射_第1頁
SSH輕量級(jí)框架實(shí)踐課件:Hibernate的關(guān)聯(lián)映射_第2頁
SSH輕量級(jí)框架實(shí)踐課件:Hibernate的關(guān)聯(lián)映射_第3頁
SSH輕量級(jí)框架實(shí)踐課件:Hibernate的關(guān)聯(lián)映射_第4頁
SSH輕量級(jí)框架實(shí)踐課件:Hibernate的關(guān)聯(lián)映射_第5頁
已閱讀5頁,還剩7頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

Hibernate的關(guān)聯(lián)映射本章目標(biāo)掌握單向多對(duì)一關(guān)聯(lián)掌握單向一對(duì)多關(guān)聯(lián)掌握雙向一對(duì)多關(guān)聯(lián)掌握多對(duì)多關(guān)聯(lián)面向?qū)ο箢I(lǐng)域的關(guān)聯(lián)關(guān)系回顧一下面向?qū)ο箢I(lǐng)域內(nèi)對(duì)象和對(duì)象間的關(guān)聯(lián)關(guān)系。以租房系統(tǒng)中的區(qū)縣和街道為例,區(qū)縣和街道之間的關(guān)系是典型的一對(duì)多關(guān)系,一個(gè)區(qū)縣下管轄多個(gè)街道,多個(gè)街道同屬于一個(gè)區(qū)縣。關(guān)聯(lián)關(guān)系的映射配置

與對(duì)象關(guān)系中的關(guān)聯(lián)關(guān)系類似,數(shù)據(jù)庫的表與表之間也存在著關(guān)聯(lián)關(guān)系,主要以外鍵的形式體現(xiàn)。圖5-4所示的是區(qū)縣表和街道表間的關(guān)聯(lián)關(guān)系。單向多對(duì)一關(guān)聯(lián)的映射我們首先考慮單向多對(duì)一的情況。實(shí)體類的定義如示例代碼5-1所示。通過Jd類的Qx屬性體現(xiàn)了兩個(gè)類之間的關(guān)聯(lián)。Jd屬于多的一方,所以這是一種典型的單向多對(duì)一關(guān)聯(lián)單向一對(duì)多關(guān)聯(lián)的映射Qx類的定義中加上Set類型的jds屬性。最終Qx類的定義如示例代碼5-4<hibernate-mappingpackage="com.xtgj.j2ee.chapter05.entity"><classname="QX"table="TBL_QX"><idname="qxid"column="qxid"type="integer"/><propertyname="qx"column="qx"type="string"not-null="false"/><setname="jds"inverse="true"lazy="false"cascade="all"> <key> <columnname="qxid"/> </key> <one-to-manyclass="com.xtgj.j2ee.chapter05.entity.JD"/></set></class></hibernate-mapping>多對(duì)多關(guān)聯(lián)的映射比多對(duì)一(many-to-one)的配置稍微麻煩一點(diǎn),需要?jiǎng)?chuàng)建一個(gè)<set>節(jié)點(diǎn),其name屬性對(duì)應(yīng)到Qx類的ids屬性。<set>節(jié)點(diǎn)下需要建立兩個(gè)子節(jié)點(diǎn),一個(gè)<key>節(jié)點(diǎn),通過其column屬性指定“多”的一方的外鍵字段名(注意:這里是TBL_JD表的字段名);一個(gè)<one-to-many>節(jié)點(diǎn),通過其class屬性指定關(guān)聯(lián)到的“多”的一方的類別。只需要配置這3個(gè)信息即可。雙向一對(duì)多關(guān)聯(lián)的映射單向一對(duì)多和單向多對(duì)一可以分別配置使用。如果同時(shí)配置了兩者,就成了雙向一對(duì)多關(guān)聯(lián)。其實(shí)在前面我們就已經(jīng)完成了雙向一對(duì)多關(guān)聯(lián)的配置。配置關(guān)聯(lián)時(shí),我們需要考慮兩點(diǎn):第一,程序執(zhí)行效率,第二,實(shí)際業(yè)務(wù)的需要。比如在前面的例子中,加載街道的同時(shí)獲得對(duì)應(yīng)區(qū)縣的信息,這給編碼帶來了極大的便利,但是我們并不是很需要通過區(qū)縣對(duì)象直接得到下屬的所有街道的數(shù)據(jù),加載區(qū)縣數(shù)據(jù)時(shí)就自動(dòng)加載街道信息也會(huì)帶來性能上的損失。這時(shí),我們只需要配置單向的多對(duì)一關(guān)聯(lián)就好了。通過程序維護(hù)關(guān)系

修改關(guān)聯(lián)關(guān)系現(xiàn)在我們要實(shí)現(xiàn)的功能是將原屬于“山南區(qū)”的“和平路”劃歸“海淀區(qū)”,即修改實(shí)體對(duì)象間的關(guān)聯(lián)關(guān)系。在前面我們?cè)趨^(qū)縣到街道的一對(duì)多關(guān)系的配置節(jié)點(diǎn)<set>上增加了inverse屬性!并設(shè)置為true,由多的一方負(fù)責(zé)關(guān)聯(lián)關(guān)系的管理。也就是說,我們通過更新街道對(duì)象,就能更新對(duì)應(yīng)的關(guān)聯(lián)關(guān)系。試一下,看看是不是可以達(dá)到效果。刪除數(shù)據(jù)在set節(jié)點(diǎn)中增加cascade屬性,值設(shè)為“all”。可選的值包括:a11:對(duì)所有的操作都進(jìn)行級(jí)聯(lián)none:對(duì)所有的操作都不進(jìn)行級(jí)聯(lián)save-update:執(zhí)行更新操作時(shí)級(jí)聯(lián)delete:執(zhí)行刪除操作時(shí)級(jí)聯(lián)現(xiàn)在我們只要?jiǎng)h除區(qū)縣記錄就可以自動(dòng)刪除關(guān)聯(lián)的街道記錄了。如圖5-17所示,自動(dòng)執(zhí)行了從tbl_jd表刪除記錄的delete語句。多對(duì)多關(guān)聯(lián)配置多對(duì)多關(guān)聯(lián)通過程序維護(hù)多對(duì)多關(guān)聯(lián)使用Hibernate,我們采用面向?qū)α愕姆绞讲僮鲾?shù)據(jù),管理對(duì)象間的關(guān)聯(lián)關(guān)系時(shí)也是采用這樣的思路。首先要做的是做好關(guān)聯(lián)的配置,通過配置關(guān)聯(lián),Hibernate就會(huì)自動(dòng)幫我們加載關(guān)聯(lián)的數(shù)據(jù),以及進(jìn)行其他持久化操作。在編寫代碼的時(shí)候,我們心里只有對(duì)象,再也不用去管數(shù)據(jù)庫、表和SQL語句了。總結(jié)本章提供了幾個(gè)例子,展示了應(yīng)用Ajax技術(shù)改善用戶體驗(yàn)的方法。相信這些例子可以幫助你在短時(shí)間內(nèi)體驗(yàn)AJAX的方便、靈活、人性化的

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論