session.createQuery("from User").list();
session.createQuery("from User").iterate();
区别:
·在生成list或interator时,list会将每个对象全部取出,而iterate仅仅取出每个对象的id(主键),等需要用到该对象时,再去取出整个对象。
·在同一个session中,每次生成list时,都会发SQL语句,并将取出的对象放入(或刷新)缓存;而每次生成iterate时,只会在第一次发出SQL语句,并将取出的对象放入缓存,以后再遍历时,若缓存中有,则直接从缓存中取,若缓存中没有,则去数据库取。
若想精益求精,则在第一次取对象时使用list(让其往session缓存中装东西),之后再使用iterate