Hibernate : Query.list()、Query.iterator()的區別
来源:百度文库 编辑:神马文学网 时间:2024/06/13 09:13:52
Hibernate : Query.list()、Query.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()方法來清除快取。
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()方法來清除快取。
Hibernate : Query.list()、Query.iterator()的區別
ARQ - SPARQL Tutorial - First Query
SPARQL Query Language for RDF
Ask Tom: On Joins and Query Plans
MATLAB Warning: Could not query OpenGL
MySQL Query Browser使用教程-狂野之城-搜狐博客
Oracle 9i闪回查询(Flashback Query)
struts2前台用标签迭代显示list中的内容代码
struts2 标签的使用 s:iterator
struts2 标签的使用 s:iterator
Hibernate效率的问题
hibernate的一级缓存
hibernate的查询缓存
自己收集整理的Eclipse plugin list
自己收集整理的Eclipse plugin list
你的To-Do List有效吗
List、Set、数组之间的转换
to-do list 的可行性艺术
字符数组和List的互相转化
我的瓦苇植物列表-list
HDU?1237?STL?的list初级使用
List、Set、数组之间的转换
ArrayList和LinedList的用法以及for-each循环语句和Iterator...
Struts2中 s:iterator 标签的使用详解及OGNL用法