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

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

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

    隨筆-124  評論-49  文章-56  trackbacks-0

    session flush測試:

    session flush方法主要做了兩件事:
    1 清理緩存
    2 執(zhí)行sql(不是提交事務(wù))

    session在什么情況下執(zhí)行flush
    1 默認(rèn)在事務(wù)提交時(shí)
    2 顯式的調(diào)用flush
    3 在執(zhí)行查詢前,如:iterate

    hibernate按照save(insert),update,delete順序提交相關(guān)的操作
    ------------------------------------------------------------------------

      <id name="id">
       <generator class="uuid"/>
      </id>
      因?yàn)閕d的主鍵生成策略采用的是uuid,所以調(diào)用完save后,只是將user對象納入到session的管理
      不會發(fā)出insert語句,但是id已經(jīng)生成,session中existsInDatebase狀態(tài)為false
      session.save(user);
      調(diào)用flush,hibernate會清理緩存,執(zhí)行sql
      如果數(shù)據(jù)庫的隔離級別為提交讀,那么我們可以看到flush過的數(shù)據(jù)
      并且session中existsInDatebase狀態(tài)變?yōu)閠rue
      session.flush();
      默認(rèn)情況下commit操作會先執(zhí)行者flush清理緩存,所以不用顯式的調(diào)用flush
      commit后數(shù)據(jù)無法回滾
      session.getTransaction().commit();
      
      <id name="id">
       <generator class="native"/>
      </id>
      如果id的主鍵生成策略采用的是native,調(diào)用save(user)時(shí)會發(fā)出insert語句,返回由數(shù)據(jù)庫生成的id,
      user對象納入到session的管理,session中existsInDatebase狀態(tài)為true
    -----------------------------------------------------------------
      <id name="id">
       <generator class="uuid"/>
      </id>
      session.save(user);
      將user對象從session中逐出,即session的EntiryEntries屬性中逐出
      session.evict(user);//清理緩存
      無法成功提交,因?yàn)閔ibernate在清理緩存時(shí),在session的insertions集合中取出user對象進(jìn)行insert操作后
      需要更新entityEntries屬性中的existsnDatabase為true,而我們采用evict已經(jīng)將user從session中
      逐出了,所以找不到相關(guān)數(shù)據(jù),無法更新,拋出異常
      session.getTransaction().commit();
    ----------------------------------------------------------------
      <id name="id">
       <generator class="uuid"/>
      </id>
      session.save(user);
      flush后hibernate會清理緩存,會將user對象保存到數(shù)據(jù)庫中,將session中的insertions中的user
      清除,并且設(shè)置session中existsInDatabase的狀態(tài)為true
      session.flush(user);
      將user對象從session中逐出,即session的EntityEntries屬性中逐出
      session.evict(user);//清理緩存
      可以成功提交,因?yàn)閔ibernate在清理緩存時(shí),在session的insertions集合中無法找到user對象
      所以就不會發(fā)出insert語句,也不會更新session中的existsInDatabase的狀態(tài)
      session.getTransaction().commit();
    -----------------------------------------------------------------
      <id name="id">
       <generator class="native"/>
      </id>
      session.save(user);
      將user對象從session中逐出,即session的EntityEntries屬性中逐出
      session.evict(user);//清理緩存
      可以成功提交,因?yàn)閔ibernate在清理緩存時(shí),在session的insertions集合中無法找到user對象
      所以就不會發(fā)出insert語句,也不會更新session中的existsInDatabase的狀態(tài)
      session.getTransaction().commit();
    -----------------------------------------------------------------
        <id name="id">
       <generator class="assigned"/>
      </id>
      session.save(user);
      user.setName("張三");
      session.update(user);
      User user2=new User();
      user2.setId("003");
      user2.setName("李四");
      session.getTransaction().commit();
      結(jié)果:
      insert into ...
      insert into ...
      update t_user ...
      hibernate按照save(insert),update,delete順序提交相關(guān)的操作
    -----------------------------------------------------------------
       <id name="id">
       <generator class="assigned"/>
      </id>
      session.save(user);
      user.setName("張三");
      session.update(user);
      因?yàn)槲覀冊趕ession.update(user)后執(zhí)行了flush,所以在以commit清理緩存時(shí)執(zhí)行flush前的sql就不會發(fā)出.
      session.flush();//在這里flush操作就可以了
      
      User user2=new User();
      user2.setId("003");
      user2.setName("李四");
      session.getTransaction().commit();
      結(jié)果:
      insert into ...
      update t_user ...
      insert into ...
      按照我們想要順序save(insert),update,save(insert)的順序提交操作
    -----------------------------------------------------------------

    posted on 2009-11-03 16:37 junly 閱讀(1234) 評論(1)  編輯  收藏 所屬分類: hibernate/orm

    評論:
    # re: hibernate基礎(chǔ)-Session_Flush 2014-04-15 00:00 | rejk
    你怎么查到的>?>  回復(fù)  更多評論
      
    主站蜘蛛池模板: 精品亚洲视频在线观看 | 18禁成人网站免费观看| 亚洲乱亚洲乱妇24p| 女人被男人躁的女爽免费视频| 日韩免费一区二区三区在线| 亚洲精品国产精品乱码不卡| 中文字幕在线亚洲精品| 亚洲欧洲国产日韩精品| 亚洲精品国产综合久久久久紧| 最新亚洲成av人免费看| 在线天堂免费观看.WWW| 亚洲精品国产va在线观看蜜芽| 特级毛片爽www免费版| 无码国产精品一区二区免费式影视| 精品亚洲国产成AV人片传媒| 国产精品hd免费观看| 四虎影院免费在线播放| 亚洲国产午夜精品理论片在线播放 | 亚洲成av人片在www鸭子| 性做久久久久免费看| 亚洲大片免费观看| 中国一级全黄的免费观看| 破了亲妺妺的处免费视频国产| 亚洲男人天堂av| www视频免费看| 亚洲天堂在线播放| 无码国产精品一区二区免费式影视 | 久久精品国产亚洲AV不卡| 日本免费A级毛一片| 亚洲国产精品激情在线观看| 亚洲精品无码国产片| 又粗又硬免费毛片| 亚洲avav天堂av在线网毛片| 九九九精品成人免费视频| 亚洲天堂一区在线| 国产成人精品高清免费| 最新国产成人亚洲精品影院| 1000部拍拍拍18勿入免费视频软件 | 久久久国产精品无码免费专区| 亚洲日产无码中文字幕| 一个人免费播放在线视频看片|