Hibernate : Query.list()、Query.iterator()的區別

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快取,所以在查詢大量數據時,會耗用大量的內存,必要時可以使用Sessionevict()clear()方法來清除快取。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章