Hibernate问题-read-write缓存策略

read-write是严格的读取策略。在将一个对象放到缓存时,同时会加一把锁。在当前session没有关闭的情况下,其他session不可以访问缓存中的同一个对象。真到此锁定的session关闭。

@Test

public void testUpdate(){

Session s2 = HibernateUtils.openSession();

Person p1 = (Person) s2.get(Person.class, "402881e4345a53ce01345a543b9a0004");

 System.out.println("第一次查询"+p1);  //查询获取一个新的对象

s2.clear();                        //将一级缓存中的数据清除

boolean boo =                      //判断二级缓存中,是否存在此对象,为true

HibernateUtils.getSessionFactory().getCache() .containsEntity(Person.class,"402881e4345a53ce01345a543b9a0004");

 System.out.println("是否存在这个对象:"+boo);//true

 Person p2 = (Person) s2.get(Person.class, "402881e4345a53ce01345a543b9a0004");//read-writeg下为什么不查二级缓存

 System.out.println("同一个session第二次查询"+p2);//使用同一个session查询,结果因为是read-write //因为对象已经上锁,所以不会从二级缓存中返回数据//s2.close();                            //关闭或是不关闭

System.out.println("上一个Session关闭以后");

Session s3 = HibernateUtils.openSession();

 boo = HibernateUtils.getSessionFactory() .getCache() .containsEntity(Person.class,"402881e4345a53ce01345a543b9a0004");

 System.out.println("是否存在这个对象:"+boo);//true

Person p3 = (Person) s3.get(Person.class, "402881e4345a53ce01345a543b9a0004");//read-write下,为什么这儿查二级缓存

System.out.println(p3);

 s3.close();

}



你可能感兴趣的:(Hibernate问题-read-write缓存策略)