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

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

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

    hibernate持久層操作

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

     

     



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

     

     



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

     

     



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

     

     



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

     

     


     

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

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

    <2025年5月>
    27282930123
    45678910
    11121314151617
    18192021222324
    25262728293031
    1234567

    導(dǎo)航

    統(tǒng)計(jì)

    公告

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

    常用鏈接

    留言簿(2)

    隨筆分類

    隨筆檔案

    文章分類

    文章檔案

    搜索

    最新評(píng)論

    閱讀排行榜

    評(píng)論排行榜

    主站蜘蛛池模板: 亚洲国产成人九九综合| 亚洲美日韩Av中文字幕无码久久久妻妇| 亚洲精品无码专区在线在线播放| 国产精品亚洲专区一区| 免费看大美女大黄大色| 亚洲精品无码专区| 日韩视频免费一区二区三区| 亚洲色欲啪啪久久WWW综合网| 成全影视免费观看大全二| 亚洲精品无码中文久久字幕| 精品国产精品久久一区免费式| 美女扒开尿口给男人爽免费视频| 国产一级淫片免费播放电影 | 中文字幕亚洲综合久久综合| 亚洲免费二区三区| 亚洲日韩中文字幕一区| 国产在线a不卡免费视频| 五月天婷婷免费视频| 国产亚洲3p无码一区二区| 免费A级毛片av无码| 国产精品亚洲一区二区麻豆| 无码国模国产在线观看免费| 美女扒开尿口给男人爽免费视频 | 九九久久国产精品免费热6| 中文字幕在线亚洲精品| 午夜视频免费在线观看| 中文字幕 亚洲 有码 在线| 国产在线观看www鲁啊鲁免费| 成人特级毛片69免费观看| 亚洲av无码国产精品夜色午夜 | 国产精品亚洲高清一区二区| 国产成人免费AV在线播放| 亚洲最大视频网站| 国产一级做a爱免费视频| 女同免费毛片在线播放| 亚洲精品无码中文久久字幕| 亚洲成色WWW久久网站| 免费无码A片一区二三区| 久久久精品国产亚洲成人满18免费网站 | 免费下载成人电影| sihu国产精品永久免费|