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 能放入一级缓存的,问什么现在不起效呢。
关于hibernate一级缓存问题
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- 你我他联盟 2015-03-10 06:43关注
Query query = sessionFactory.getCurrentSession().createQuery(hql);
解决 无用评论 打赏 举报