一般正常来说,我们认为发送两次相同的查询,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),所以直接返回。