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

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

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

    隨筆-61  評論-159  文章-0  trackbacks-0
             在hibernate中,由于一級緩存的生命周期跟Session的生命周期一樣,所以也可以理解為一級緩存是session緩存。
             一、通過在做查詢的時候,有幾個查詢方法支持一級緩存,它們分別是:load(),get(),iterate(),其中要注意的是iterate方法只對實體對象查詢才支持一級緩存,如果使用iterate來查詢對象里面的相關屬性,則查詢的時候不支持一級緩存。
    1、load()方法。
    例子:
    1Student s = (Student)session.load(Student.class1);
    2            System.out.println(s.getName());
    3            System.out.println("---------------------");
    4            s = (Student)session.load(Student.class1);
    5            System.out.println(s.getName());
    PS:只發出一條sql語句,雖然這里使用兩次load方法,但是第一次load方法對于id為1的記錄進行加載,到第3行才發出一條sql語句及符合的數據,這樣就把數據放在一級緩存里面,在第4行開始繼續使用load就從一級緩存里面抽取。

    2、get()方法。
    例子:
    1Student s = (Student)session.get(Student.class1);
    2            System.out.println(s.getName());
    3            System.out.println("---------------------");
    4            s = (Student)session.load(Student.class1);
    5            System.out.println(s.getName());
    PS:跟1中load一樣,只發出一條sql語句。

    3、iterate()方法查詢實體對象
    例子:
    1Student student = (Student)session.createQuery("from Student s where s.id=1").iterate().next();
    2            System.out.println("student.name=" + student.getName());
    3            
    4            //會發出查詢id的sql,不會發出查詢實體對象的sql,因為iterate使用緩存
    5            student = (Student)session.createQuery("from Student s where s.id=1").iterate().next();
    6            System.out.println("student.name=" + student.getName());
    PS:總共發出3條sql語句,1、2行發出兩條語句,1條是查詢實體對象的sql,另一條是查詢實體對象的name屬性,由于使用一級緩存,之前1、2行查詢的實體存放在一級緩存里面,所以5、6行利用一級緩存里面的數據只發出一條查詢id的sql。

    4、iterate()方法查詢實體對象屬性(不支持一級緩存)
    例子:
    1String name = (String)session.createQuery("select s.name from Student s where s.id=1").iterate().next();
    2            System.out.println("student.name=" + name);
    3            
    4            //iterate查詢普通屬性,一級緩存不會緩存,所以發出sql
    5            //一級緩存是緩存實體對象的
    6            name = (String)session.createQuery("select s.name from Student s where s.id=1").iterate().next();
    7            System.out.println("student.name=" + name);

    PS:由于iterate()方法查詢實體對象屬性,一級緩存不會產生作用,所以發出兩條sql語句。

           二、一級緩存是存在的,所以要更加合理的管理好,提高程序的效率,通常都是通過clear(),evict()方法來清除緩存,當不需要使用一級緩存或者是更加高效率使用一級緩存。
                  如果在一次性更新或者加入數量量比較大的情況下,更加要管理好一級緩存。
    例子:
     1for(int i=0;i<10000;i++)
     2            {
     3                Student s = new Student();
     4                s.setName("s"+i);
     5                session.save(s);
     6                if(i%20==0)
     7                {
     8                    session.flush();
     9                    session.clear();
    10                }

    11            }
    PS:在數據量比較大的情況下管理一級緩存的做法,一般都是設定一定數量的記錄給更新或者保存等操作之后,避免一次性大量的實體數據入庫導致內存溢出,所以才去先是用第8行的flush和第9行的clear方法來實現比較好的緩存管理。在數據量特別大的時候,可以使用jdbc來實現,因為hibernate不太適合于數據量特別大的場合使用,如果連jdbc都滿足不了數據量的效率要求,只好利用相關的數據庫機制來實現。


    -------------------------------------------------------------------------------------------------
    PS:本博客文章,如果沒有注明是有“轉”字樣,屬于本人原創。如果需要轉載,務必注明作者文章的詳細出處地址,否則不允許轉載,多謝合作!
    posted on 2008-10-31 23:39 apple0668 閱讀(801) 評論(0)  編輯  收藏 所屬分類: hibernate
    主站蜘蛛池模板: 国产亚洲成av人片在线观看| 亚洲国产av一区二区三区| 国产AV无码专区亚洲AV男同| 日本一区二区三区在线视频观看免费 | 毛片a级毛片免费观看品善网| 亚洲一区二区久久| 99re热免费精品视频观看| 亚洲乱码一区二区三区国产精品| 免费av欧美国产在钱| 亚洲精品自偷自拍无码| 日本免费一本天堂在线| 羞羞漫画登录页面免费| 中文字幕亚洲激情| 美女视频黄a视频全免费网站色窝 美女被cao网站免费看在线看 | 久久永久免费人妻精品| 亚洲成人一级电影| 免费人成在线视频| 亚洲av无码成人影院一区| 亚洲成a人在线看天堂无码| 一级毛片在播放免费| 亚洲欧洲美洲无码精品VA| 在线观看免费无码专区| 666精品国产精品亚洲| 久久精品免费全国观看国产| 亚洲风情亚Aⅴ在线发布| 亚洲精品无码专区久久同性男| 久久免费国产精品| 亚洲欧洲日产韩国在线| 精品无码国产污污污免费| 人妻巨大乳hd免费看| 亚洲成人激情在线| 午夜dj在线观看免费视频| 一区二区免费国产在线观看| 亚洲av日韩av天堂影片精品| 大地资源在线观看免费高清| 色费女人18女人毛片免费视频| 久久久久亚洲精品美女| 成人免费视频软件网站| 国产一级在线免费观看| 亚洲人成激情在线播放| 国产精品亚洲精品日韩已方|