list方法:当咱们查询多条记录的时候咱们使用list结构来接收查询结果,这时候hibernate会根据咱们设置的lazy值来选择查询时机,而一旦查询了,则是把多条记录所有查询出来。sql
iterate方法:当咱们查询多条记录的时候使用iterate方法。用一个iterator结构来接收,这时候hibernate也会根据lazy的设置来选择查询时机,开始查询了,并不会把咱们要查询的全部记录查询出来,而是查询全部记录的主键,只有迭代到哪一个对象再经过该对象的主键再进行查询。session
总结:但咱们查询的记录为N,list方式只执行1条sql语句,而iterate方式则是要看咱们迭代几条记录,若是迭代M条记录,则会执行 M+1条sql语句。测试
例如:spa
测试代码:.net
@Test public void testIterator01(){ Session session = Util.getSession(); Transaction ts = session.beginTransaction(); List<User> users = session.createCriteria(User.class).list(); for(User u : users){ System.out.println("name:"+u.getUsername()); } ts.commit(); Util.closeSession(); session = Util.getSession(); ts = session.beginTransaction(); String hql = "from User "; Iterator<User> results =session.createQuery(hql).iterate(); for(;results.hasNext();){ System.out.println("name:"+results.next().getUsername()); } ts.commit(); Util.closeSession(); } |