隨筆 - 18, 文章 - 0, 評論 - 8, 引用 - 0
          數(shù)據(jù)加載中……

          [轉(zhuǎn)帖]Hibernate常用保存

          hibernate對于對象的保存提供了太多的方法,他們之間有很多不同,這里細(xì)說一下,以便區(qū)別:
          一、預(yù)備知識:
          在所有之前,說明一下,對于hibernate,它的對象有三種狀態(tài),transient、persistent、detached
          下邊是常見的翻譯辦法:
          transient:瞬態(tài)或者自由態(tài)
          persistent:持久化狀態(tài)
          detached:脫管狀態(tài)或者游離態(tài)
          脫管狀態(tài)的實(shí)例可以通過調(diào)用save()、persist()或者saveOrUpdate()方法進(jìn)行持久化。
          持久化實(shí)例可以通過調(diào)用 delete()變成脫管狀態(tài)。通過get()或load()方法得到的實(shí)例都是持久化狀態(tài)的。
          脫管狀態(tài)的實(shí)例可以通過調(diào)用 update()、0saveOrUpdate()、lock()或者replicate()進(jìn)行持久化。
          save() 和persist()將會引發(fā)SQL的INSERT,delete()會引發(fā)SQLDELETE,而update()或merge()會引發(fā) SQLUPDATE.對持久化(persistent)實(shí)例的修改在刷新提交的時候會被檢測到,它也會引起 SQLUPDATE.saveOrUpdate()或者replicate()會引發(fā)SQLINSERT或者UPDATE
          二、save 和update區(qū)別
          把這一對放在第一位的原因是因?yàn)檫@一對是最常用的。
          save的作用是把一個新的對象保存
          update是把一個脫管狀態(tài)的對象保存
          三、update 和saveOrUpdate區(qū)別
          這個是比較好理解的,顧名思義,saveOrUpdate基本上就是合成了save和update引用hibernate reference中的一段話來解釋他們的使用場合和區(qū)別。
          通常下面的場景會使用update()或saveOrUpdate():
          程序在第一個session中加載對象
          該對象被傳遞到表現(xiàn)層
          對象發(fā)生了一些改動
          該對象被返回到業(yè)務(wù)邏輯層
          程序調(diào)用第二個session的update()方法持久這些改動
          saveOrUpdate()做下面的事:
          如果對象已經(jīng)在本session中持久化了,不做任何事
          如果另一個與本session關(guān)聯(lián)的對象擁有相同的持久化標(biāo)識(identifier),拋出一個異常
          如果對象沒有持久化標(biāo)識(identifier)屬性,對其調(diào)用save()
          如果對象的持久標(biāo)識(identifier)表明其是一個新實(shí)例化的對象,對其調(diào)用save()
          如果對象是附帶版本信息的(通過或) 并且版本屬性的值表明其是一個新實(shí)例化的對象,save()它。
          四、persist和save區(qū)別
          這個是最迷離的一對,表面上看起來使用哪個都行,在hibernate reference文檔中也沒有明確的區(qū)分他們。
          這里給出一個明確的區(qū)分。(可以跟進(jìn)src看一下,雖然實(shí)現(xiàn)步驟類似,但是還是有細(xì)微的差別)
          1.persist把一個瞬態(tài)的實(shí)例持久化,但是并"不保證"標(biāo)識符被立刻填入到持久化實(shí)例中,標(biāo)識符的填入可能被推遲到flush的時間。
          2.persist" 保證",當(dāng)它在一個transaction外部被調(diào)用的時候并不觸發(fā)一個Sql Insert,這個功能是很有用的,當(dāng)我們通過繼承Session/persistence context來封裝一個長會話流程的時候,一個persist這樣的函數(shù)是需要的。
          3.save"不保證"第2條,它要返回標(biāo)識符,所以它會立即執(zhí)行Sql insert,不管是不是在transaction內(nèi)部。
          五、saveOrUpdateCopy,merge和update區(qū)別
          首先說明merge是用來代替saveOrUpdateCopy的,然后比較update和merge,update的作用上邊說了,這里說一下merge的作用。
          如果session中存在相同持久化標(biāo)識(identifier)的實(shí)例,用用戶給出的對象的狀態(tài)覆蓋舊有的持久實(shí)例
          如果session沒有相應(yīng)的持久實(shí)例,則嘗試從數(shù)據(jù)庫中加載,或創(chuàng)建新的持久化實(shí)例,最后返回該持久實(shí)例
          用戶給出的這個對象沒有被關(guān)聯(lián)到session上,它依舊是脫管的
          重點(diǎn)是最后一句:
          當(dāng)我們使用update的時候,執(zhí)行完成后,我們提供的對象A的狀態(tài)變成持久化狀態(tài)
          但當(dāng)我們使用merge的時候,執(zhí)行完成,我們提供的對象A還是脫管狀態(tài),hibernate或者new了一個B,或者檢索到一個持久對象,并把我們提供的對象A的所有的值拷貝到這個B,執(zhí)行完成后B是持久狀態(tài),而我們提供的A還是托管狀態(tài)。
          六、flush和update區(qū)別
          這兩個的區(qū)別好理解
          update操作的是在脫管狀態(tài)的對象,而flush是操作的在持久狀態(tài)的對象。
          默認(rèn)情況下,一個持久狀態(tài)的對象是不需要update的,只要你更改了對象的值,等待hibernate flush就自動保存到數(shù)據(jù)庫了。hibernate flush發(fā)生再幾種情況下:
          1.調(diào)用某些查詢的時候
          2.transaction commit的時候
          3.手動調(diào)用flush的時候
          七、lock和update區(qū)別
          update是把一個已經(jīng)更改過的脫管狀態(tài)的對象變成持久狀態(tài)
          lock是把一個沒有更改過的脫管狀態(tài)的對象變成持久狀態(tài)
          對應(yīng)更改一個記錄的內(nèi)容,兩個的操作不同:
          update的操作步驟是:
          更改脫管的對象->調(diào)用update
          lock的操作步驟是:
          調(diào)用lock把對象從脫管狀態(tài)變成持久狀態(tài)——>更改持久狀態(tài)的對象的內(nèi)容——>等待flush或者手動flush

          posted on 2008-08-23 21:22 丑男 閱讀(249) 評論(0)  編輯  收藏 所屬分類: Other


          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 峨边| 扬州市| 聂拉木县| 平原县| 沂水县| 横峰县| 丁青县| 连城县| 宜章县| SHOW| 栾川县| 浏阳市| 西乡县| 基隆市| 沽源县| 舞钢市| 长泰县| 惠安县| 密山市| 化德县| 竹北市| 陆良县| 新蔡县| 义乌市| 昭苏县| 涪陵区| 山西省| 平利县| 鄂伦春自治旗| 瑞金市| 无极县| 东乡县| 新平| 漳州市| 黄大仙区| 大同县| 惠安县| 梁山县| 榆中县| 黄陵县| 元谋县|