
这里的ITERATOR和LIST有啥区别?
publicIteratorfindById(Integerid)throwsHibernateException{StringBufferstr=newStringBu...
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(); 有什么区别? 展开
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()中返回的对象是代理对象.
1:返回的类型不一样,list()返回List,iterate()返回Iterator,
2: 获取数据的方式不一样,list()会直接查数据库,iterate()会先到数据库中把id都取出来,然后真正要遍历某个对象的时候先到缓存中找,如果找不到,以id为条件再发一条sql到数据库,这样如果缓存中没有数据,则查询数据库的次数为n+1。
3:iterate会查询2级缓存, list只会查询一级缓存。
4: list()中返回的List中每个对象都是原本的对象,iterate()中返回的对象是代理对象.

2024-12-03 广告
作为北京饼干科技有限公司的一员,对于市场上各类工具都有所了解。就AiPPT而言,它确实为用户提供了便捷高效的PPT制作体验。通过智能化的辅助功能,用户能够快速生成专业且富有创意的演示文稿,极大地节省了时间和精力。无论是对于个人用户还是企业团...
点击进入详情页
本回答由AiPPT提供
展开全部
使用Iterator 节省内存,而且效率高
枚举器Iterator 是Java在后台自动排序好,比纯粹的for循环要快,因为如果用 for循环,也需要将List中的对象依次取出,这样对内存的调用是随机的,不如Iterator。
使用传统List 方法,将ResultSet中的用户名加入List再返回,显然这很耗费内存。
枚举器Iterator 是Java在后台自动排序好,比纯粹的for循环要快,因为如果用 for循环,也需要将List中的对象依次取出,这样对内存的调用是随机的,不如Iterator。
使用传统List 方法,将ResultSet中的用户名加入List再返回,显然这很耗费内存。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
iterate(),它是先查询出id,然后每次next()的时候
再查询出数据,所以它的速度很慢,仅适用结果集非常庞大的时候.
list()是一次把所有查询结果缓存到内存中,也是比较常用的,因为一次查询非常庞大的记录集的情况并不多
http://www.jdon.com/jivejdon/thread/9056.html,这贴子有JDBC和hibernate及它的list()和iterator()效率的测试,可能不是很准,不过也能说明一些问题
再查询出数据,所以它的速度很慢,仅适用结果集非常庞大的时候.
list()是一次把所有查询结果缓存到内存中,也是比较常用的,因为一次查询非常庞大的记录集的情况并不多
http://www.jdon.com/jivejdon/thread/9056.html,这贴子有JDBC和hibernate及它的list()和iterator()效率的测试,可能不是很准,不过也能说明一些问题
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询