日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
Hibernate Customer客戶對(duì)象

Hibernate有很多值得學(xué)習(xí)的地方,這里我們主要介紹Hibernate Customer客戶對(duì)象,包括介紹cascade屬性設(shè)置等方面。

我們提供的服務(wù)有:做網(wǎng)站、成都網(wǎng)站設(shè)計(jì)、微信公眾號(hào)開(kāi)發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、宜章ssl等。為近1000家企事業(yè)單位解決了網(wǎng)站和推廣的問(wèn)題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的宜章網(wǎng)站制作公司

在類和類之間建好了關(guān)聯(lián)關(guān)系之后,就可以方便的從一個(gè)對(duì)象得到它關(guān)聯(lián)的對(duì)象。例如Customer customer=order。getCustomer();這樣獲得的了Hibernate Customer客戶對(duì)象了。但是如果想獲得所有屬于Hibernate Customer客戶對(duì)象的 Order訂單對(duì)象,就涉及到了一對(duì)多雙向關(guān)聯(lián)了。在內(nèi)存中,從一個(gè)對(duì)象導(dǎo)航都另一個(gè)對(duì)象要比從數(shù)據(jù)庫(kù)中通過(guò)一個(gè)字段查詢另一個(gè)字段快的多的多,但是也給編程的時(shí)候帶來(lái)了麻煩,隨意修改一個(gè)對(duì)象就可能牽一發(fā)而動(dòng)全身,所以說(shuō)雙向的關(guān)聯(lián)比較復(fù)雜,但是類和類之間到底建立單向還是雙向關(guān)聯(lián),這個(gè)要根據(jù)業(yè)務(wù)需求來(lái)決定。比如說(shuō)業(yè)務(wù)需求根據(jù)指定客戶查詢客戶所有訂單,根據(jù)指定的訂單,查詢出發(fā)這個(gè)訂單的客戶。這個(gè)時(shí)候我們不妨用多對(duì)一雙向關(guān)聯(lián)處理。其實(shí)上邊的例子的映射文件已經(jīng)簡(jiǎn)歷了客戶和訂單之間的一對(duì)多雙向關(guān)聯(lián)關(guān)系,只不過(guò)要在客戶類中加一個(gè)集合的屬性:

 
 
 
  1. private set orders = new HashSet();  
  2. public set getOrders() {  
  3. return orders;  
  4. }  
  5. public void setOrders(Set orders) {  
  6. this.orders = orders;  

有了orders屬性,客戶就可以通過(guò)getOrders()方法或者客戶的全部訂單了,Hibernate在定義這個(gè)集合屬性的時(shí)候必須聲明為接口類型,但是不光光是Set還有Map和List,這樣可以提高程序的強(qiáng)壯性,就是說(shuō)set方法接受的對(duì)象只要是實(shí)現(xiàn)了Set接口就OK。避免出現(xiàn)null值的現(xiàn)象。這里要注意的是hbm2java工具生成類的集合屬性的代碼時(shí),不會(huì)給它初始化一個(gè)集合對(duì)象的實(shí)例,這里我們需要自己手動(dòng)修改,當(dāng)然不修改也是可以的。接下來(lái)還要在customer。hbm。xml映射文件里映射集合類型的orders屬性,當(dāng)然這個(gè)和 order表的的同理,所以不能通過(guò)普通的元素來(lái)設(shè)置屬性和字段的映射關(guān)系。要使用元素來(lái)設(shè)置:

 
 
 
  1.  name=\"orders\" cascade=\"save-update\"> 
  2.  column=\"CUSTOMER_ID\"> 
  3.  class=\"包名.Order\"> 
  4.  

name:設(shè)定類的屬性名

cascade:設(shè)置為save-update表示級(jí)聯(lián)保存更新,當(dāng)保存或更新Customer類的時(shí)候會(huì)級(jí)聯(lián)保存更新跟它關(guān)聯(lián)的Order類。
元素是用來(lái)設(shè)定跟持久化類關(guān)聯(lián)的類的外鍵
元素看起來(lái)很熟悉,哦是設(shè)置外鍵的元素反過(guò)來(lái)了。這里它是用來(lái)設(shè)置所關(guān)聯(lián)的持久化類的。這里設(shè)置為和客戶關(guān)聯(lián)的訂單Order類,這里表明這個(gè)屬性里要存放一組Order類型的對(duì)象。
元素是表示orders屬性聲明為set類型。

元素還有一個(gè)inverse屬性,這個(gè)方法主要是在給已存在數(shù)據(jù)庫(kù)中的字段建立關(guān)聯(lián)的時(shí)候很有用。就是說(shuō)當(dāng)我們獲得數(shù)據(jù)庫(kù)中的兩個(gè)表的兩條記錄的對(duì)象Hibernate Customer客戶對(duì)象和order訂單對(duì)象(映射文件已經(jīng)建立了他們類和類之間的關(guān)聯(lián),但外鍵的值為null的情況下)然后我們想建立這個(gè)客戶對(duì)象和訂單對(duì)象之間的關(guān)聯(lián),我們要先調(diào)用order。setCustomer(customer);然后在調(diào)用 customer。getOrder()。add(order);在Hibernate自動(dòng)清理緩存的持久化對(duì)象的時(shí)候會(huì)提交兩條SQL語(yǔ)句。進(jìn)行了兩個(gè)update操作。但是實(shí)際上只修改了一條記錄。重復(fù)的執(zhí)行SQL語(yǔ)句是會(huì)降低系統(tǒng)的運(yùn)行效率的,當(dāng)把inverse屬性設(shè)置為true的時(shí)候,同樣的操作就會(huì)合并到一條SQL語(yǔ)句執(zhí)行了,inverse默認(rèn)為false;

級(jí)聯(lián)刪除就很簡(jiǎn)單了,把cascade屬性設(shè)置為delete,如果你刪除了一個(gè)客戶,程序就會(huì)先執(zhí)行刪除這個(gè)客戶全部的訂單的SQL語(yǔ)句,然后在刪除這個(gè)客戶,所謂刪除一個(gè)持久化對(duì)象不是在內(nèi)存中刪除這個(gè)對(duì)象,而是刪除數(shù)據(jù)庫(kù)中相關(guān)的記錄,這個(gè)對(duì)象依然在內(nèi)存中,只不過(guò)由持久化狀態(tài)轉(zhuǎn)為臨時(shí)狀態(tài),當(dāng)這個(gè)對(duì)象的引用消失后,這個(gè)對(duì)象會(huì)被垃圾回收。但是如果我又想級(jí)聯(lián)刪除,還想級(jí)聯(lián)保存,更新的時(shí)候應(yīng)該怎么辦呢?這個(gè)時(shí)候我們將cascade屬性設(shè)置為 all-delete-orphan就OK了。非常簡(jiǎn)單明了。我們還可以通過(guò)持久化類的 customer。getOrder()。rumove(order);解除關(guān)聯(lián)。這里的操作表示獲得客戶訂單的集合對(duì)象,然后從集合對(duì)象中刪除 order的訂單,其實(shí)這種操作的意義不大,當(dāng)我們不需要的這個(gè)訂單的時(shí)候完全可以刪除它,解除關(guān)聯(lián)之后如果設(shè)置了級(jí)聯(lián)刪除屬性,這個(gè)無(wú)用的記錄也是要被刪除的。其實(shí)解除關(guān)聯(lián)就是把外鍵設(shè)為null。通常我們的外鍵都要約束不可以為空。

【編輯推薦】

  1. 簡(jiǎn)單描述Hibernate單元測(cè)試
  2. 概括Hibernate多表關(guān)聯(lián)查詢
  3. 淺談Hibernate Session Factory
  4. 淺析Hibernate加載配置文件
  5. 深入剖析Hibernate核心接口

文章名稱:Hibernate Customer客戶對(duì)象
新聞來(lái)源:http://m.5511xx.com/article/cdhdcop.html