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);
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。