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 优华 阅读(5490) 评论(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
????????????????????????????????  回复  更多评论
  


只有注册用户登录后才能发表评论。


网站导航: