Query上有l(wèi)ist()與iterator()方法,兩者的差別在於list()方法在讀取資料時(shí),並不會(huì)利用到快取,而是直接再向資料庫(kù)查詢,而iterator()則將讀取到的資料寫(xiě)到快取,並於讀取時(shí)再次利用。
來(lái)看看下面的程式:
Session session = sessionFactory.openSession();
Query query = session.createQuery("from User");
List users = query.list();
users = query.list();
session.close();
Query query = session.createQuery("from User");
List users = query.list();
users = query.list();
session.close();
這個(gè)程式片段會(huì)使用兩次SQL來(lái)查詢資料庫(kù):
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_
Hibernate: select user0_.id as id, user0_.name as name0_, user0_.age as age0_ from user user0_
如果在Session關(guān)閉之前,要再將所有資料在取出,可以使用iterator()方法,例如:
Session session = sessionFactory.openSession();
Query query = session.createQuery("from User");
Iterator users = query.iterate();
users = query.iterate();
session.close();
Query query = session.createQuery("from User");
Iterator users = query.iterate();
users = query.iterate();
session.close();
這個(gè)程式片段會(huì)使用一次SQL向資料庫(kù)查詢,第二次則直接從快取中取得資料:
Hibernate: select user0_.id as col_0_0_ from user user0_
由於使用iterator()方法時(shí)會(huì)使用到Session level快取,所以在查詢大量資料時(shí),會(huì)耗用大量的記憶體,必要時(shí)可以使用Session的evict()或clear()方法來(lái)清除快取。