konhon

          忘掉過去,展望未來。找回自我,超越自我。
          逃避不一定躲的過, 面對不一定最難過, 孤單不一定不快樂, 得到不一定能長久, 失去不一定不再擁有, 可能因為某個理由而傷心難過, 但我卻能找個理由讓自己快樂.

          Google

          BlogJava 首頁 新隨筆 聯系 聚合 管理
            203 Posts :: 0 Stories :: 61 Comments :: 0 Trackbacks

           

          Query上有list()與iterator()方法,兩者的差別在於list()方法在讀取資料時,並不會利用到快取,而是直接再向資料庫查詢,而iterator()則將讀取到的資料寫到快取,並於讀取時再次利用。

          來看看下面的程式:
          Session session = sessionFactory.openSession();
                 
          Query query = session.createQuery("from User");
          List users = query.list();
          users = query.list();

          session.close();

          這個程式片段會使用兩次SQL來查詢資料庫:
          Hibernate: select user0_.id as id, user0_.name as name0_, user0_.age as age0_ from user user0_
          Hibernate: select user0_.id as id, user0_.name as name0_, user0_.age as age0_ from user user0_

          如果在Session關閉之前,要再將所有資料在取出,可以使用iterator()方法,例如:
          Session session = sessionFactory.openSession();

          Query query = session.createQuery("from User");
          Iterator users = query.iterate();
          users = query.iterate();

          session.close();

          這個程式片段會使用一次SQL向資料庫查詢,第二次則直接從快取中取得資料:
          Hibernate: select user0_.id as col_0_0_ from user user0_

          由於使用iterator()方法時會使用到Session level快取,所以在查詢大量資料時,會耗用大量的記憶體,必要時可以使用Session的evict()或clear()方法來清除快取。
          posted on 2005-08-11 22:25 konhon 優華 閱讀(5493) 評論(2)  編輯  收藏 所屬分類: Hibernate

          Feedback

          # re: Hibernate : Query.list()、Query.iterator()的區別 2007-06-27 03:14 nn
          是不是寫反了  回復  更多評論
            

          # re: Hibernate : Query.list()、Query.iterator()的區別 2007-06-27 03:15 nn
          ????????????????????????????????  回復  更多評論
            

          主站蜘蛛池模板: 凯里市| 玛纳斯县| 云霄县| 潮州市| 长岭县| 日照市| 靖边县| 七台河市| 鹤岗市| 博野县| 建水县| 廉江市| 桃源县| 扎赉特旗| 景洪市| 芜湖县| 尼玛县| 仙居县| 高台县| 安吉县| 延安市| 余江县| 广南县| 高尔夫| 嘉兴市| 麻江县| 武功县| 芜湖县| 贵港市| 潼关县| 石阡县| 阿克陶县| 家居| 萨嘎县| 西乡县| 东安县| 临邑县| 讷河市| 和平区| 曲麻莱县| 永平县|