开发者社区> 问答> 正文

关于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 能放入一级缓存的,问什么现在不起效呢。

展开
收起
小旋风柴进 2016-03-17 09:13:04 2064 0
1 条回答
写回答
取消 提交回答
  • Query query = sessionFactory.getCurrentSession().createQuery(hql);

    2019-07-17 19:04:25
    赞同 展开评论 打赏
问答分类:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载