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

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

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

    Java信徒

      BlogJava :: 首頁 :: 聯系 :: 聚合  :: 管理
      2 Posts :: 1 Stories :: 0 Comments :: 0 Trackbacks

    深入淺出Hibernate P281講到使用Hibernate3的Bulk delete/update方式刪除記錄時,寫了段代碼證明這種刪除方式不能緩存同步,會從緩存中讀取出數據庫已經刪除的信息,我依葫蘆畫瓢寫了段代碼,結果與書上結論相反,
    請大家幫我看看到底怎么回事,我用的hibernate3.0,代碼如下:



    package mypack;

    import org.hibernate.Query;
    import org.hibernate.Session;
    import org.hibernate.Transaction;
    import sessionfactory.HibernateSessionFactory;

    public class test2 {

    ?/**
    ? * @param args
    ? */


    ?public static void main(String[] args) {
    ? //儲存插入記錄的id
    ??int insertid;
    ??//新建實例
    ??TUser insertuser = new TUser();
    ??insertuser.setName("name1");
    ??insertuser.setResume("resume1");
    ??//插入實例
    ??Session session = HibernateSessionFactory.getSession();
    ??Transaction tx = session.beginTransaction();??
    ??session.save(insertuser);
    ??insertid = insertuser.getId();
    ??tx.commit();
    ??session.close();
    ??
    ??// 裝載插入的實例
    ??session = HibernateSessionFactory.getSession();
    ??TUser user = (TUser) session.load(TUser.class, new Integer(insertid));
    ??System.out.println("裝載實例成功,id==>" + user.getId());
    ??tx = session.beginTransaction();
    ??// 刪除插入的實例
    ??String hql = "delete TUser where id = "+insertid;
    ??Query query = session.createQuery(hql);
    ??query.executeUpdate();
    ??tx.commit();
    ??// 讀取刪除的實例,拋出異常
    ??user = (TUser) session.load(TUser.class, new Integer(insertid));
    ??System.out.println("讀取緩存中存放的id成功, id==>" + user.getId());
    ??// 捕捉異常
    ??try {
    ???System.out.println(user.getName());
    ??} catch (org.hibernate.ObjectNotFoundException e) {
    ???System.out.println("代碼user.getname()發生異常,因為該實例已經被刪除");
    ???System.out.println(e.toString());
    ???System.out.println("結論:Query.execxuteUpdate()方法刪除數據是緩存同步的");
    ??}
    ??session.close();
    ?}
    }


    打印信息如下:

    Hibernate: insert into tuser (name, resume) values (?, ?)
    裝載實例成功,id==>43
    Hibernate: delete from tuser where id=43
    讀取緩存中存放的id成功, id==>43
    Hibernate: select tuser0_.id as id0_, tuser0_.name as name0_0_, tuser0_.resume as resume0_0_ from tuser tuser0_ where tuser0_.id=?
    代碼user.getname()發生異常,因為該實例已經被刪除
    org.hibernate.ObjectNotFoundException: No row with the given identifier exists: [mypack.TUser#43]
    結論:Query.execxuteUpdate()方法刪除數據是緩存同步的
    posted on 2007-01-16 18:18 庸世俗才 閱讀(853) 評論(0)  編輯  收藏

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


    網站導航:
     
    主站蜘蛛池模板: 亚洲三级电影网站| 国产一级黄片儿免费看| 日韩视频在线精品视频免费观看 | 美女视频黄频a免费| 噼里啪啦免费观看高清动漫4| 亚洲AV无码一区二区乱子伦| 国产精品成人啪精品视频免费| 四虎永久精品免费观看| 亚洲第一综合天堂另类专| 免费看国产精品3a黄的视频 | 另类免费视频一区二区在线观看| 亚洲色图综合在线| 四虎精品免费永久免费视频| 国产aa免费视频| 亚洲AV无码国产一区二区三区| 巨胸喷奶水视频www网免费| 亚洲xxxx视频| 成年人免费观看视频网站| 亚洲国产日韩精品| 大陆一级毛片免费视频观看i| 亚洲中文无码亚洲人成影院| 毛片视频免费观看| 亚洲一区在线免费观看| 可以免费看黄的网站| 亚洲伊人精品综合在合线| 成人午夜免费福利视频| 精品亚洲国产成人| 成年女人喷潮毛片免费播放| 亚洲精品综合在线影院| 成人免费午夜视频| 亚洲成a∧人片在线观看无码| 国产高清在线精品免费软件| 综合偷自拍亚洲乱中文字幕| 免费大片黄手机在线观看| 全部在线播放免费毛片| 亚洲精品亚洲人成在线观看下载 | 美女视频黄频a免费| 亚洲无码精品浪潮| 在线观看免费视频网站色| 亚洲av永久无码精品漫画 | 亚洲欧美乱色情图片|