hibernate持久層操作

          Session.get/load的區(qū)別:
                1.如果未能發(fā)現(xiàn)符合條件的記錄,get方法返回null,而load方法會拋出一個ObejctNotFoundException。
                2.Load方法可返回實體的代理類類型,而get方法永遠直接返回實體類。
                3.Load方法可以充分利用內(nèi)部緩存和二級緩存中現(xiàn)有數(shù)據(jù),而get方法則僅僅在內(nèi)部緩存中進行數(shù)據(jù)查找,如沒有發(fā)現(xiàn)對應(yīng)數(shù)據(jù),將越過二級緩存,直接調(diào)用SQL完成數(shù)據(jù)讀取。

           

           



                Session.find/iterate的區(qū)別:
                find方法將執(zhí)行Select SQL從數(shù)據(jù)庫中獲得所有符合條件的記錄并構(gòu)造相應(yīng)的實體對象,實體對象構(gòu)建完畢之后,就將其納入緩存。它對緩存只寫不讀,因此無法利用緩存。
                iterate方法首先執(zhí)行一條Select SQL以獲得所有符合查詢條件的數(shù)據(jù)id,隨即,iterate方法首先在本地緩存中根據(jù)id查找對應(yīng)的實體對象是否存在,如果緩存中已經(jīng)存在對應(yīng)的數(shù)據(jù),則直接以此數(shù)據(jù)對象作為查詢結(jié)果,如果沒有找到,再執(zhí)行相應(yīng)的Select語句獲得對應(yīng)的庫表記錄(iterate方法如果執(zhí)行了數(shù)據(jù)庫讀取操作并構(gòu)建了完整的數(shù)據(jù)對象,也會將其查詢結(jié)果納入緩存)。

           

           



                Query Cache產(chǎn)生作用的情況:
                1.完全相同的Select SQL重復(fù)執(zhí)行。
                2.在兩次查詢之間,此Select SQL對應(yīng)的庫表沒有發(fā)生過改變。

           

           



                Session.save方法的執(zhí)行步驟:
                1.在Session內(nèi)部緩存中尋找待保存對象。內(nèi)部緩存命中,則認(rèn)為此數(shù)據(jù)已經(jīng)保存(執(zhí)行過insert操作),實體對象已經(jīng)處于Persistent狀態(tài),直接返回。
                2.如果實體類實現(xiàn)了lifecycle接口,則調(diào)用待保存對象的onSave方法。
                3.如果實體類實現(xiàn)了validatable接口,則調(diào)用其validate()方法。
                4.調(diào)用對應(yīng)攔截器的Interceptor.onSave方法(如果有的話)。
                5.構(gòu)造Insert SQL,并加以執(zhí)行。
                6.記錄插入成功,user.id屬性被設(shè)定為insert操作返回的新記錄id值。
                7.將user對象放入內(nèi)部緩存。
                8.最后,如果存在級聯(lián)關(guān)系,對級聯(lián)關(guān)系進行遞歸處理。

           

           



                Session.update方法的執(zhí)行步驟:
                1.根據(jù)待更新實體對象的Key,在當(dāng)前session的內(nèi)部緩存中進行查找,如果發(fā)現(xiàn),則認(rèn)為當(dāng)前實體對象已經(jīng)處于Persistent狀態(tài),返回。
                2.初始化實體對象的狀態(tài)信息(作為之后臟數(shù)據(jù)檢查的依據(jù)),并將其納入內(nèi)部緩存。注意這里Session.update方法本身并沒有發(fā)送Update SQL完成數(shù)據(jù)更新操作,Update SQL將在之后的Session.flush方法中執(zhí)行(Transaction.commit在真正提交數(shù)據(jù)庫事務(wù)之前會調(diào)用Session.flush)。

           

           


           

                Session.saveOrUpdate方法的執(zhí)行步驟:
                1.首先在Session內(nèi)部緩存中進行查找,如果發(fā)現(xiàn)則直接返回。
                2.執(zhí)行實體類對應(yīng)的Interceptor.isUnsaved方法(如果有的話),判斷對象是否為未保存狀態(tài)。
                3.根據(jù)unsaved-value判斷對象是否處于未保存狀態(tài)。
                4.如果對象未保存(Transient狀態(tài)),則調(diào)用save方法保存對象。
                5.如果對象為已保存(Detached狀態(tài)),調(diào)用update方法將對象與Session重新關(guān)聯(lián)。

          posted on 2009-03-26 00:09 MichaelLee 閱讀(177) 評論(0)  編輯  收藏 所屬分類: Hibernate

          <2025年7月>
          293012345
          6789101112
          13141516171819
          20212223242526
          272829303112
          3456789

          導(dǎo)航

          統(tǒng)計

          公告

          ====Michael Lee====
          =Java Sofware Engineer=
          =Work @ Beijing=
          ---再煩,也別忘微笑;再急,也要注意語氣;再苦,也別忘堅持;再累,也要愛自己!---
          ---低調(diào)做人,你會一次比一次穩(wěn)健;高調(diào)做事,你會一次比一次優(yōu)秀---
          ---成功的時候不要忘記過去;失敗的時候不要忘記還有未來---

          常用鏈接

          留言簿(2)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          搜索

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 正镶白旗| 泸西县| 嘉祥县| 邮箱| 莎车县| 富宁县| 临城县| 惠来县| 嘉黎县| 江阴市| 安庆市| 犍为县| 罗江县| 周至县| 云南省| 敦煌市| 靖远县| 丰台区| 互助| 桑日县| 石阡县| 大余县| 湾仔区| 宜丰县| 墨玉县| 安仁县| 成安县| 德兴市| 疏附县| 苏尼特左旗| 黄山市| 壤塘县| 中宁县| 周宁县| 虞城县| 丹寨县| 萨嘎县| 荃湾区| 昂仁县| 蓝田县| 信宜市|