Hibernate中iterate方法与list方法的区别

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();     }
相关文章
相关标签/搜索