关于hibernate一级缓存问题

    Team team = (Team) meaulInter.executeQueryById(Team.class, 1);
    System.out.println(team.getName());
    Team team2 = (Team) meaulInter.executeQueryById(Team.class, 1);
    System.out.println(team2.getName());

    这段代码中,meaulInter类里面有一个查询方法,其中在这里,查询出来的结构能够放入一级缓存(SQL语句只发出一次)

    但是

    List<Team> teams = meaulInter.executeQuery("from Team");
    System.out.println(teams);
List<Team> teams2 = meaulInter.executeQuery("from Team");
    System.out.println(teams2);

    其中meaulInter封装了一个查询全部的方法,返回的是 query.list(),
    为什么这样就不能放入一级缓存,SQL语句发出2次。

    其中executeQuery()方法代码如下:
    public List executeQuery(String hql, Object... prameters) {
    Query query = sessionFactory.getCurrentSession().createQuery(hql);
    if(prameters!=null&&prameters.length>0){
        for (int i = 0; i < prameters.length; i++) {
            query.setParameter(i, prameters[i]);
        }
    }
        return query.list();
}

求大神指点下,我查阅过资料,说 list 能放入一级缓存的,问什么现在不起效呢。

Query query = sessionFactory.getCurrentSession().createQuery(hql);