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

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

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

    隨筆-9  評論-0  文章-0  trackbacks-0
    .
    可能現(xiàn)在大家常常還會遇到一個些面試的時候問一些關(guān)于hibernate的問題,我個人覺得,這些東西一般做過開發(fā)的人在使用上沒有任何的問題的,但是如果是要你來說就不一定能夠說好的,下面是從goole上找的一些常見的面試。
    1.Hibernate session接口的get和load方法有何異同?
    答: 其實它們也沒有什么不同的, 作用其實都是一樣的,但是有一定的區(qū)別,get是每次都會從數(shù)據(jù)庫取數(shù)據(jù)以保證數(shù)據(jù)的可靠性,而load會返回proxy,相當于是一個存根,它的值會去hibernate中的session的二級緩存里去找,如果找不到目則會laxy load一下,簡單來說,用get的時候,當為空的時候不會拋出異常,反之load會拋.

    2.在持久化層,對象分為哪些狀態(tài)?分別列出來.
    答:瞬時態(tài)(Transient)、持久態(tài)(Persistent)、脫管態(tài)(Detached)。
    瞬時態(tài)(Transient)
    是對象是創(chuàng)建時,瞬時對象在內(nèi)存孤立存在,它是攜帶信息的載體,不和數(shù)據(jù)庫的數(shù)據(jù)有任何關(guān)聯(lián)關(guān)系,在Hibernate中,可通過session的save()或 saveOrUpdate()方法將瞬時對象與數(shù)據(jù)庫相關(guān)聯(lián),并將數(shù)據(jù)對應的插入數(shù)據(jù)庫中,此時該瞬時對象轉(zhuǎn)變成持久化對象。
    持久態(tài)(Persistent)
    是該對象在數(shù)據(jù)庫中已有對應的記錄,并擁有一個持久化標識,如果是用hibernate的delete()方法,對應的持久對象就變成瞬時對象,因數(shù)據(jù)庫中的對應數(shù)據(jù)已被刪除,該對象不再與數(shù)據(jù)庫的記錄關(guān)聯(lián)。
        當一個session執(zhí)行close()或clear()、evict()之后,持久對象變成脫管對象,此時持久對象會變成脫管對象,此時該對象雖然具有數(shù)據(jù)庫識別值,但它已不在hibernate持久層的管理之下。
      持久對象具有如下特點:
         1. 和session實例關(guān)聯(lián);
         2. 在數(shù)據(jù)庫中有與之關(guān)聯(lián)的記錄。
    脫管態(tài)(Detached)
    當與某持久對象關(guān)聯(lián)的session被關(guān)閉后,該持久對象轉(zhuǎn)變?yōu)槊摴軐ο蟆.斆摴軐ο蟊恢匦玛P(guān)聯(lián)到session上時,并再次轉(zhuǎn)變成持久對象。
           脫管對象擁有數(shù)據(jù)庫的識別值,可通過update()、saveOrUpdate()等方法,轉(zhuǎn)變成持久對象。
           脫管對象具有如下特點:
      1.本質(zhì)上與瞬時對象相同,在沒有任何變量引用它時,JVM會在適當?shù)臅r候?qū)⑺厥眨?
    2. 比瞬時對象多了一個數(shù)據(jù)庫記錄標識值。
    3.lock和update區(qū)別
    答: update是把一個已經(jīng)更改過的脫管狀態(tài)的對象變成持久狀態(tài)
    lock是把一個沒有更改過的脫管狀態(tài)的對象變成持久狀態(tài)(針對的是因Session的關(guān)閉 而處于脫管狀態(tài)的po對象(2),不能針對因delete而處于脫管狀態(tài)的po對象)
    對應更改一個記錄的內(nèi)容,兩個的操作不同:
    update的操作步驟是:
    (1)屬性改動后的脫管的對象的修改->調(diào)用update
    lock的操作步驟是:
    (2)調(diào)用lock把未修改的對象從脫管狀態(tài)變成持久狀態(tài)-->更改持久狀態(tài)的對象的內(nèi)容-->等待flush或者手動flush
    4.save 和update區(qū)別
    答: save是把一個對象做為一個新的數(shù)據(jù)保存, update則是把一個脫管狀態(tài)的對象或自由態(tài)對象(一定要和一個記錄對應)更新到數(shù)據(jù)庫,其實一個是保存一個是更新,一看都知道是有什么區(qū)別了。
    5.update 和saveOrUpdate區(qū)別
    答:這個是比較好理解的,顧名思義,saveOrUpdate基本上就是合成了save和update,而update只是update;引用hibernate reference中的一段話來解釋他們的使用場合和區(qū)別
    通常下面的場景會使用update()或saveOrUpdate():
    程序在第一個session中加載對象,接著把session關(guān)閉
    該對象被傳遞到表現(xiàn)層
    對象發(fā)生了一些改動
    該對象被返回到業(yè)務邏輯層最終到持久層
    程序創(chuàng)建第二session調(diào)用第二個session的update()方法持久這些改動
    saveOrUpdate(po)做下面的事:
    如果該po對象已經(jīng)在本session中持久化了,在本session中執(zhí)行saveOrUpdate不做任何事
    如果savaOrUpdate(新po)與另一個與本session關(guān)聯(lián)的po對象擁有相同的持久化標識(identifier),拋出一個異常
    org.hibernate.NonUniqueObjectException: a different object with the same identifier value was already associated with the session: [org.itfuture.www.po.Xtyhb#5]
    saveOrUpdate如果對象沒有持久化標識(identifier)屬性,對其調(diào)用save() ,否則update() 這個對象     
    6.flush和update區(qū)別
    答:這兩個的區(qū)別好理解update操作的是在自由態(tài)或脫管狀態(tài)(因session的關(guān)閉而處于脫管狀態(tài))的對象//updateSQL
    而flush是操作的在持久狀態(tài)的對象。
    默認情況下,一個持久狀態(tài)的對象的改動(包含set容器)是不需要update的,只要你更改了對象的值,等待hibernate flush就自動更新或保存到數(shù)據(jù)庫了。hibernate flush發(fā)生在以下幾種情況中:
    1, 調(diào)用某些查詢的和手動flush(),session的關(guān)閉、SessionFactory關(guān)閉結(jié)合
    get()一個對象,把對象的屬性進行改變,把資源關(guān)閉。
    2,transaction commit的時候(包含了flush)
    posted on 2010-03-05 21:44 AndyFish 閱讀(191) 評論(0)  編輯  收藏

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


    網(wǎng)站導航:
     
    主站蜘蛛池模板: 久久精品免费一区二区三区| 国产精品亚洲专区在线播放| 久久久久免费精品国产小说| 中文字幕精品亚洲无线码二区| 丁香花在线观看免费观看| 日韩亚洲AV无码一区二区不卡 | 亚洲中文字幕丝袜制服一区| 特黄特色大片免费| 亚洲精品国产福利一二区| 色多多A级毛片免费看| 亚洲一级片免费看| 国产黄片不卡免费| 亚洲国产成人片在线观看无码 | 在线观看免费无码视频| 亚洲爆乳无码一区二区三区| 亚洲视频在线免费观看| 亚洲日韩乱码中文无码蜜桃臀| g0g0人体全免费高清大胆视频| 亚洲免费日韩无码系列| 久草免费福利视频| 国产精品亚洲综合久久| 国产成人3p视频免费观看| 国产乱子伦精品免费视频| 国产成人精品免费直播| 深夜福利在线视频免费| 久久久久久亚洲精品| 日韩免费精品视频| 国产亚洲精品91| 亚洲AV无码成人精品区在线观看| 精品无码免费专区毛片| 朝桐光亚洲专区在线中文字幕| 77777亚洲午夜久久多人| www.免费在线观看| 美女视频黄.免费网址| 亚洲国产女人aaa毛片在线| 久久久久国产精品免费免费搜索| 无码人妻一区二区三区免费视频| 亚洲综合在线观看视频| 国产女高清在线看免费观看| 今天免费中文字幕视频| 亚洲av午夜国产精品无码中文字|