这里的ITERATOR和LIST有啥区别?

来源:百度知道 编辑:UC知道 时间:2024/06/24 11:04:16
public Iterator findById(Integer id)throws HibernateException{
StringBuffer str=new StringBuffer();
str.append("SELECT * FROM test_user where id = ");
str.append(id);
Query query=session.createQuery(str.toString());
Iterator it=query.iterate();
return it;
这里如果把ITERATOR换成LIST有啥区别吗?
听人家说返回的是个结果集, 那Iterator it=query.itrator(); 和List it=query.list(); 有什么区别?

区别如下:
1:返回的类型不一样,list()返回List,iterate()返回Iterator,
2: 获取数据的方式不一样,list()会直接查数据库,iterate()会先到数据库中把id都取出来,然后真正要遍历某个对象的时候先到缓存中找,如果找不到,以id为条件再发一条sql到数据库,这样如果缓存中没有数据,则查询数据库的次数为n+1。
3:iterate会查询2级缓存, list只会查询一级缓存。
4: list()中返回的List中每个对象都是原本的对象,iterate()中返回的对象是代理对象.

iterate(),它是先查询出id,然后每次next()的时候
再查询出数据,所以它的速度很慢,仅适用结果集非常庞大的时候.
list()是一次把所有查询结果缓存到内存中,也是比较常用的,因为一次查询非常庞大的记录集的情况并不多

http://www.jdon.com/jivejdon/thread/9056.html,这贴子有JDBC和hibernate及它的list()和iterator()效率的测试,可能不是很准,不过也能说明一些问题

使用Iterator 节省内存,而且效率高
枚举器Iterator 是Java在后台自动排序好,比纯粹的for循环要快,因为如果用 for循环,也需要将List中的对象依次取出,这样对内存的调用是随机的,不如Iterator。
使用传统List 方法,将ResultSet中的用户名加入List再返回,显然这很耗费内存。