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

我們提供的服務(wù)有:做網(wǎng)站、成都網(wǎng)站設(shè)計(jì)、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、宜章ssl等。為近1000家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的宜章網(wǎng)站制作公司
在類和類之間建好了關(guān)聯(lián)關(guān)系之后,就可以方便的從一個對象得到它關(guān)聯(lián)的對象。例如Customer customer=order。getCustomer();這樣獲得的了Hibernate Customer客戶對象了。但是如果想獲得所有屬于Hibernate Customer客戶對象的 Order訂單對象,就涉及到了一對多雙向關(guān)聯(lián)了。在內(nèi)存中,從一個對象導(dǎo)航都另一個對象要比從數(shù)據(jù)庫中通過一個字段查詢另一個字段快的多的多,但是也給編程的時候帶來了麻煩,隨意修改一個對象就可能牽一發(fā)而動全身,所以說雙向的關(guān)聯(lián)比較復(fù)雜,但是類和類之間到底建立單向還是雙向關(guān)聯(lián),這個要根據(jù)業(yè)務(wù)需求來決定。比如說業(yè)務(wù)需求根據(jù)指定客戶查詢客戶所有訂單,根據(jù)指定的訂單,查詢出發(fā)這個訂單的客戶。這個時候我們不妨用多對一雙向關(guān)聯(lián)處理。其實(shí)上邊的例子的映射文件已經(jīng)簡歷了客戶和訂單之間的一對多雙向關(guān)聯(lián)關(guān)系,只不過要在客戶類中加一個集合的屬性:
- private set orders = new HashSet();
- public set getOrders() {
- return orders;
- }
- public void setOrders(Set orders) {
- this.orders = orders;
- }
有了orders屬性,客戶就可以通過getOrders()方法或者客戶的全部訂單了,Hibernate在定義這個集合屬性的時候必須聲明為接口類型,但是不光光是Set還有Map和List,這樣可以提高程序的強(qiáng)壯性,就是說set方法接受的對象只要是實(shí)現(xiàn)了Set接口就OK。避免出現(xiàn)null值的現(xiàn)象。這里要注意的是hbm2java工具生成類的集合屬性的代碼時,不會給它初始化一個集合對象的實(shí)例,這里我們需要自己手動修改,當(dāng)然不修改也是可以的。接下來還要在customer。hbm。xml映射文件里映射集合類型的orders屬性,當(dāng)然這個和 order表的的
name=\"orders\" cascade=\"save-update\"> column=\"CUSTOMER_ID\"> class=\"包名.Order\">
name:設(shè)定類的屬性名
cascade:設(shè)置為save-update表示級聯(lián)保存更新,當(dāng)保存或更新Customer類的時候會級聯(lián)保存更新跟它關(guān)聯(lián)的Order類。
◆
◆
◆
級聯(lián)刪除就很簡單了,把cascade屬性設(shè)置為delete,如果你刪除了一個客戶,程序就會先執(zhí)行刪除這個客戶全部的訂單的SQL語句,然后在刪除這個客戶,所謂刪除一個持久化對象不是在內(nèi)存中刪除這個對象,而是刪除數(shù)據(jù)庫中相關(guān)的記錄,這個對象依然在內(nèi)存中,只不過由持久化狀態(tài)轉(zhuǎn)為臨時狀態(tài),當(dāng)這個對象的引用消失后,這個對象會被垃圾回收。但是如果我又想級聯(lián)刪除,還想級聯(lián)保存,更新的時候應(yīng)該怎么辦呢?這個時候我們將cascade屬性設(shè)置為 all-delete-orphan就OK了。非常簡單明了。我們還可以通過持久化類的 customer。getOrder()。rumove(order);解除關(guān)聯(lián)。這里的操作表示獲得客戶訂單的集合對象,然后從集合對象中刪除 order的訂單,其實(shí)這種操作的意義不大,當(dāng)我們不需要的這個訂單的時候完全可以刪除它,解除關(guān)聯(lián)之后如果設(shè)置了級聯(lián)刪除屬性,這個無用的記錄也是要被刪除的。其實(shí)解除關(guān)聯(lián)就是把外鍵設(shè)為null。通常我們的外鍵都要約束不可以為空。
【編輯推薦】
- 簡單描述Hibernate單元測試
- 概括Hibernate多表關(guān)聯(lián)查詢
- 淺談Hibernate Session Factory
- 淺析Hibernate加載配置文件
- 深入剖析Hibernate核心接口
文章名稱:Hibernate Customer客戶對象
文章URL:http://www.5511xx.com/article/cdhdcop.html


咨詢
建站咨詢
