hibernate中的HQL到底用没用一级缓存?

一般正常来说,我们认为发送两次相同的查询,hibernate中是只会打印一次sql(也就是访问数据库),第二次再进行查询时,会从一级缓存中拿。
那HQL也用了一级缓存么?俺们来验证下:

//Hql查询,查询结果会放入Session一级缓存中.但是每次调用Hql查询都会生成Sql语句?
// 并不代表 Hql没有使用1级缓存. 
public class Demo2 {
    @Test
    public void fun1(){
        Session session = HibernateUtils.openSession();
        session.beginTransaction();
        //------------------------------------------------
        List<User> list1 = session.createQuery("from User").list(); // 发送sql

        List<User> list2 = session.createQuery("from User").list();// 发送sql

        System.out.println(list1.get(0)==list2.get(0));//true =>  
        //------------------------------------------------
        session.getTransaction().commit();
        session.close(); // 游离状态
    }

上述代码运行后得出的结果是true,难道是HQL没有使用一级缓存么?
下图执行过程原理图:
这里写图片描述
1—-5的步骤是list1 ,5步骤后是list2的执行过程,当执行到步骤8时session中已经存在了该对象(oid),所以直接返回。

猜你喜欢

转载自blog.csdn.net/qq_36866808/article/details/79468583