已遷址

          已遷址http://www.cnblogs.com/live365wang/

            BlogJava :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
            28 隨筆 :: 0 文章 :: 1 評(píng)論 :: 0 Trackbacks


          hibernate的狀態(tài)
          hibernate的各種保存方式的區(qū)(save,persist,update,saveOrUpdte,merge,flush,lock)及 對(duì)象的三種狀態(tài)
          hibernate的保存
          hibernate對(duì)于對(duì)象的保存提供了太多的方法,他們之間有很多不同,這里細(xì)說(shuō)一下,以便區(qū)別。


          一、預(yù)備知識(shí)
          在所有之前,說(shuō)明一下,對(duì)于hibernate,它的對(duì)象有三種狀態(tài),transient、persistent、detached
          下邊是常見的翻譯辦法:


          transient:瞬態(tài)或者自由態(tài)
              (new DeptPo(1,”行政部”,20,”行政相關(guān)”),該po的實(shí)例和session沒(méi)有關(guān)聯(lián),該po的實(shí)例處于transient)


          persistent:持久化狀態(tài)
              (和數(shù)據(jù)庫(kù)中記錄想影射的Po實(shí)例,它的狀態(tài)是persistent, 通過(guò)get和load等得到的對(duì)象都是persistent)

           


          detached:脫管狀態(tài)或者游離態(tài)
              (1)當(dāng)通過(guò)get或load方法得到的po對(duì)象它們都處于persistent,但如果執(zhí)行delete(po)時(shí)(但不能執(zhí)行事務(wù)),該po狀態(tài)就處于detached, (表示和session脫離關(guān)聯(lián)),因delete而變成游離態(tài)可以通過(guò)save或saveOrUpdate()變成持久態(tài)
              (2)當(dāng)把session關(guān)閉時(shí),session緩存中的persistent的po對(duì)象也變成detached
          因關(guān)閉session而變成游離態(tài)的可以通過(guò)lock、save、update變成持久態(tài)
          持久態(tài)實(shí)例可以通過(guò)調(diào)用 delete()變成脫管狀態(tài)。
              通過(guò)get()或load()方法得到的實(shí)例都是持久化狀態(tài)的。
              脫管狀態(tài)的實(shí)例可以通過(guò)調(diào)用lock()或者replicate()進(jìn)行持久化。

              save()和persist()將會(huì)引發(fā)SQL的INSERT,delete()會(huì)引發(fā)SQLDELETE,
          而update()或merge()會(huì)引發(fā)SQL UPDATE。對(duì)持久化(persistent)實(shí)例的修改在刷新提交的時(shí)候會(huì)被檢測(cè)到,它也會(huì)引起SQL UPDATE。
              saveOrUpdate()或者replicate()會(huì)引發(fā)SQLINSERT或者UPDATE


          二、save 和update區(qū)別
               把這一對(duì)放在第一位的原因是因?yàn)檫@一對(duì)是最常用的。
               save的作用是把一個(gè)新的對(duì)象保存
               update是把一個(gè)脫管狀態(tài)的對(duì)象或自由態(tài)對(duì)象(一定要和一個(gè)記錄對(duì)應(yīng))更新到數(shù)據(jù)庫(kù)

          三、update 和saveOrUpdate區(qū)別
              這個(gè)是比較好理解的,顧名思義,saveOrUpdate基本上就是合成了save和update,而update只是update;引用hibernate reference中的一段話來(lái)解釋他們的使用場(chǎng)合和區(qū)別
          通常下面的場(chǎng)景會(huì)使用update()或saveOrUpdate(): 
              程序在第一個(gè)session中加載對(duì)象,接著把session關(guān)閉 
              該對(duì)象被傳遞到表現(xiàn)層 
              對(duì)象發(fā)生了一些改動(dòng) 
              該對(duì)象被返回到業(yè)務(wù)邏輯層最終到持久層 
              程序創(chuàng)建第二session調(diào)用第二個(gè)session的update()方法持久這些改動(dòng) 

          saveOrUpdate(po)做下面的事: 
              如果該po對(duì)象已經(jīng)在本session中持久化了,在本session中執(zhí)行saveOrUpdate不做任何事 
              如果savaOrUpdate(新po)與另一個(gè)與本session關(guān)聯(lián)的po對(duì)象擁有相同的持久化標(biāo)識(shí)(identifier),拋出一個(gè)異常 
          org.hibernate.NonUniqueObjectException: a different object with the same identifier value was already associated with the session: [org.itfuture.www.po.Xtyhb#5]
              saveOrUpdate如果對(duì)象沒(méi)有持久化標(biāo)識(shí)(identifier)屬性,對(duì)其調(diào)用save() ,否則update() 這個(gè)對(duì)象 

          四、persist和save區(qū)別
              這個(gè)是最迷離的一對(duì),表面上看起來(lái)使用哪個(gè)都行,在hibernate reference文檔中也沒(méi)有明確的區(qū)分他們.
          這里給出一個(gè)明確的區(qū)分。(可以跟進(jìn)src看一下,雖然實(shí)現(xiàn)步驟類似,但是還是有細(xì)微的差別)
          主要內(nèi)容區(qū)別:
          1,persist把一個(gè)瞬態(tài)的實(shí)例持久化,但是并"不保證"標(biāo)識(shí)符(identifier主鍵對(duì)應(yīng)的屬性)被立刻填入到持久化實(shí)例中,標(biāo)識(shí)符的填入可能被推遲到flush的時(shí)候。

          2,save, 把一個(gè)瞬態(tài)的實(shí)例持久化標(biāo)識(shí)符,及時(shí)的產(chǎn)生,它要返回標(biāo)識(shí)符,所以它會(huì)立即執(zhí)行Sql insert

          五、saveOrUpdate,merge和update區(qū)別
          比較update和merge
              update的作用上邊說(shuō)了,這里說(shuō)一下merge的
              如果session中存在相同持久化標(biāo)識(shí)(identifier)的實(shí)例,用用戶給出的對(duì)象覆蓋session已有的持久實(shí)例 
          (1)當(dāng)我們使用update的時(shí)候,執(zhí)行完成后,會(huì)拋出異常 
          (2)但當(dāng)我們使用merge的時(shí)候,把處理自由態(tài)的po對(duì)象A的屬性copy到session當(dāng)中處于持久態(tài)的po的屬性中,執(zhí)行完成后原來(lái)是持久狀態(tài)還是持久態(tài),而我們提供的A還是自由態(tài)

          六、flush和update區(qū)別
              這兩個(gè)的區(qū)別好理解
              update操作的是在自由態(tài)或脫管狀態(tài)(因session的關(guān)閉而處于脫管狀態(tài))的對(duì)象//updateSQL
              而flush是操作的在持久狀態(tài)的對(duì)象。
              默認(rèn)情況下,一個(gè)持久狀態(tài)的對(duì)象的改動(dòng)(包含set容器)是不需要update的,只要你更改了對(duì)象的值,等待hibernate flush就自動(dòng)更新或保存到數(shù)據(jù)庫(kù)了。hibernate flush發(fā)生在以下幾種情況中:
          1, 調(diào)用某些查詢的和手動(dòng)flush(),session的關(guān)閉、SessionFactory關(guān)閉結(jié)合 
          get()一個(gè)對(duì)象,把對(duì)象的屬性進(jìn)行改變,把資源關(guān)閉。
          2,transaction commit的時(shí)候(包含了flush)

          七、lock和update區(qū)別
              update是把一個(gè)已經(jīng)更改過(guò)的脫管狀態(tài)的對(duì)象變成持久狀態(tài)
              lock是把一個(gè)沒(méi)有更改過(guò)的脫管狀態(tài)的對(duì)象變成持久狀態(tài)(針對(duì)的是因Session的關(guān)閉而處于脫管狀態(tài)的po對(duì)象(2),不能針對(duì)因delete而處于脫管狀態(tài)的po對(duì)象)
          對(duì)應(yīng)更改一個(gè)記錄的內(nèi)容,兩個(gè)的操作不同:
          update的操作步驟是:
          (1)屬性改動(dòng)后的脫管的對(duì)象的修改->調(diào)用update
          lock的操作步驟是:
          (2)調(diào)用lock把未修改的對(duì)象從脫管狀態(tài)變成持久狀態(tài)-->更改持久狀態(tài)的對(duì)象的內(nèi)容-->等待flush或者手動(dòng)flush


          八、clear和evcit的區(qū)別
          clear完整的清除session緩存
             evcit(obj)把某個(gè)持久化對(duì)象從session的緩存中清空。


          session.lock(xtyhb,LockMode.NONE);//表示直接到緩存中去找變成持久態(tài)的對(duì)象

          session.lock(xtyhb,LockMode.READ);//先通過(guò)ID讀數(shù)據(jù)庫(kù)該記錄的ID看是否有該記錄,如果有接著到緩存中去找變成持久態(tài)的對(duì)象


          本文轉(zhuǎn)自:http://hi.baidu.com/anypcao/blog/item/fd8943e7f4930324b93820d6.html

          posted on 2011-02-22 13:44 已遷址 閱讀(127) 評(píng)論(0)  編輯  收藏 所屬分類: Hibernate
          主站蜘蛛池模板: 阿坝| 青冈县| 永丰县| 太仓市| 青海省| 蒙山县| 临泉县| 资阳市| 周至县| 平遥县| 襄汾县| 永春县| 通山县| 常山县| 岳西县| 托克逊县| 方山县| 峨边| 桂东县| 福清市| 呼图壁县| 金塔县| 三亚市| 永康市| 甘德县| 赤壁市| 汉沽区| 衡山县| 乌拉特前旗| 伊通| 南陵县| 麦盖提县| 当涂县| 大冶市| 响水县| 浠水县| 会同县| 洪雅县| 孝昌县| 安乡县| 龙海市|