<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-348  評(píng)論-598  文章-0  trackbacks-0

    Hibernate的對(duì)象有3種狀態(tài),分別為:瞬時(shí)態(tài)(Transient)、 持久態(tài)(Persistent)、脫管態(tài)(Detached)。處于持久態(tài)的對(duì)象也稱(chēng)為PO(Persistence Object),瞬時(shí)對(duì)象和脫管對(duì)象也稱(chēng)為VO(Value Object)。
    瞬時(shí)態(tài)
            由new命令開(kāi)辟內(nèi)存空間的java對(duì)象,

           eg. Person person = new Person("xxx", "xx");

            如果沒(méi)有變量對(duì)該對(duì)象進(jìn)行引用,它將被java虛擬機(jī)回收。

             瞬時(shí)對(duì)象在內(nèi)存孤立存在,它是攜帶信息的載體,不和數(shù)據(jù)庫(kù)的數(shù)據(jù)有任何關(guān)聯(lián)關(guān)系,在Hibernate中,可通過(guò)session的save()或saveOrUpdate()方法將瞬時(shí)對(duì)象與數(shù)據(jù)庫(kù)相關(guān)聯(lián),并將數(shù)據(jù)對(duì)應(yīng)的插入數(shù)據(jù)庫(kù)中,此時(shí)該瞬時(shí)對(duì)象轉(zhuǎn)變成持久化對(duì)象。

    持久態(tài)
            處于該狀態(tài)的對(duì)象在數(shù)據(jù)庫(kù)中具有對(duì)應(yīng)的記錄,并擁有一個(gè)持久化標(biāo)識(shí)。如果是用hibernate的delete()方法,對(duì)應(yīng)的持久對(duì)象就變成瞬時(shí)對(duì)象,因數(shù)據(jù)庫(kù)中的對(duì)應(yīng)數(shù)據(jù)已被刪除,該對(duì)象不再與數(shù)據(jù)庫(kù)的記錄關(guān)聯(lián)。

           當(dāng)一個(gè)session執(zhí)行close()或clear()、evict()之后,持久對(duì)象變成脫管對(duì)象,此時(shí)持久對(duì)象會(huì)變成脫管對(duì)象,此時(shí)該對(duì)象雖然具有數(shù)據(jù)庫(kù)識(shí)別值,但它已不在HIbernate持久層的管理之下。

           持久對(duì)象具有如下特點(diǎn):

            1. 和session實(shí)例關(guān)聯(lián);

           2. 在數(shù)據(jù)庫(kù)中有與之關(guān)聯(lián)的記錄。

    脫管態(tài)
            當(dāng)與某持久對(duì)象關(guān)聯(lián)的session被關(guān)閉后,該持久對(duì)象轉(zhuǎn)變?yōu)槊摴軐?duì)象。當(dāng)脫管對(duì)象被重新關(guān)聯(lián)到session上時(shí),并再次轉(zhuǎn)變成持久對(duì)象。

           脫管對(duì)象擁有數(shù)據(jù)庫(kù)的識(shí)別值,可通過(guò)update()、saveOrUpdate()等方法,轉(zhuǎn)變成持久對(duì)象。

           脫管對(duì)象具有如下特點(diǎn):

           1. 本質(zhì)上與瞬時(shí)對(duì)象相同,在沒(méi)有任何變量引用它時(shí),JVM會(huì)在適當(dāng)?shù)臅r(shí)候?qū)⑺厥眨?/p>

            2.   比瞬時(shí)對(duì)象多了一個(gè)數(shù)據(jù)庫(kù)記錄標(biāo)識(shí)值。

     

    hibernate的各種保存方式的區(qū)(save,persist,update,saveOrUpdte,merge,flush,lock)及 對(duì)象的三種狀態(tài)
    hibernate的保存
    hibernate對(duì)于對(duì)象的保存提供了太多的方法,他們之間有很多不同,這里細(xì)說(shuō)一下,以便區(qū)別。
    一、預(yù)備知識(shí)
    對(duì)于hibernate,它的對(duì)象有三種狀態(tài),transient、persistent、detached
    下邊是常見(jiàn)的翻譯辦法:
    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中的一段話(huà)來(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)步驟類(lèi)似,但是還是有細(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í)例,用用戶(hù)給出的對(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)用某些查詢(xún)的和手動(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的緩存中清空。



    ---------------------------------------------------------
    專(zhuān)注移動(dòng)開(kāi)發(fā)

    Android, Windows Mobile, iPhone, J2ME, BlackBerry, Symbian
    posted on 2008-10-25 10:57 TiGERTiAN 閱讀(34339) 評(píng)論(7)  編輯  收藏 所屬分類(lèi): JavaHibernate

    評(píng)論:
    # re: Hibernate三種狀態(tài)的區(qū)分,以及save,update,saveOrUpdate,merge等的使用 2009-04-02 21:23 | 獨(dú)孤行
    寫(xiě)得還不錯(cuò)哦,蠻清晰,要是再來(lái)點(diǎn)緩存的機(jī)制就更好了  回復(fù)  更多評(píng)論
      
    # re: Hibernate三種狀態(tài)的區(qū)分,以及save,update,saveOrUpdate,merge等的使用[未登錄](méi) 2009-04-02 22:41 | TiGERTiAN
    @獨(dú)孤行
    呵呵,這篇文章是轉(zhuǎn)來(lái)的  回復(fù)  更多評(píng)論
      
    # 態(tài)的區(qū)分,以及save,update,saveOrUpdate,merge等的使用 2013-05-02 14:13 | 234
    1
    111111111111111111
    11111

    111
    1
    1
    1
    1
    11

    1
    1
    1
    1
    1111
    1
    1
    1
    11
    1
    1

    111111111
    1

    1
    11

    1
    1
    1
    1
    1
    1
    1
    1
    1
    111

    1
    1
    1
    1
    1
    11
    1
    1
    1
    1
    1
    1
    1
    11
    1
    1
    11
    1

    1
    1
    1
    1
    1
    1
    1
    1
    1

    1
    1
    1






































































      回復(fù)  更多評(píng)論
      
    # re: Hibernate三種狀態(tài)的區(qū)分,以及save,update,saveOrUpdate,merge等的使用 2013-11-05 22:30 | xiaoxian
    @234
    不錯(cuò)不錯(cuò)哦  回復(fù)  更多評(píng)論
      
    # re: Hibernate三種狀態(tài)的區(qū)分,以及save,update,saveOrUpdate,merge等的使用 2013-11-05 22:30 | xiaoxian
    寫(xiě)的不錯(cuò)不錯(cuò)哦  回復(fù)  更多評(píng)論
      
    # saveOrUpdate將不修改的屬性設(shè)空 2014-04-09 21:12 | EOC
    當(dāng)調(diào)用saveOrUpdate時(shí),明明指定setParent(Parent)了,可還是會(huì)產(chǎn)生條語(yǔ)句將parent屬性制空,這個(gè)該如何解決?  回復(fù)  更多評(píng)論
      
    # re: Hibernate三種狀態(tài)的區(qū)分,以及save,update,saveOrUpdate,merge等的使用[未登錄](méi) 2016-08-19 09:13 | a
    主站蜘蛛池模板: 久久精品免费观看| 亚洲男人av香蕉爽爽爽爽| 67pao强力打造67194在线午夜亚洲| 精品人妻系列无码人妻免费视频 | 国产偷国产偷亚洲高清日韩| 成a人片亚洲日本久久| 日韩激情淫片免费看| 最新亚洲人成网站在线观看| 日本特黄a级高清免费大片| 亚洲国产高清国产拍精品| 国产精品jizz在线观看免费 | 日本高清免费中文在线看| 亚洲视频在线免费| 巨胸狂喷奶水视频www网站免费| 亚洲乱码中文字幕综合| 国产偷伦视频免费观看| 99人中文字幕亚洲区| 免费一本色道久久一区| 国产亚洲福利一区二区免费看| 亚洲国产一区二区视频网站| 国产免费一区二区三区在线观看| 久久久久亚洲av无码专区| a毛片基地免费全部视频| 亚洲AV无码成人精品区狼人影院| 亚洲高清无码在线观看| 免费在线黄色电影| 亚洲一级片在线观看| 亚洲av无码天堂一区二区三区| 免费无码作爱视频| 国产成人精品日本亚洲直接| 免费va人成视频网站全| 国产精品区免费视频| 亚洲高清一区二区三区电影| 亚洲一级特黄大片在线观看| 59pao成国产成视频永久免费 | 久久91亚洲精品中文字幕| 夫妻免费无码V看片| 免费无码又爽又刺激一高潮| 亚洲首页国产精品丝袜| 国产偷窥女洗浴在线观看亚洲| 免费观看激色视频网站(性色)|