问题描述
- 关于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);
时间: 2024-09-14 09:32:01