关于Hibernate的一级缓存:
Hibernate的一级缓存就是指Session缓存,一级缓存的生命周期与Session是一致的。Session缓存是一块内存空间,用来存放相互管理的javabean对象,在使用Hibernate查询对象的时候,首先会使用对象属性的OID值在Hibernatede 一级缓存中进行查找,如果找到匹配OID的对象,就直接将该对象从一级缓存中取出使用,不会再查询数据库;如果没有找到相同OID值的对象,则会取数据库中查找相应的数据。当从数据库中查询到所需数据时,该数据信息也会放置到一级缓存中。这样做的目的就体现了hibernate的一级缓存的作用就是减少对数据库的访问次数。
Hibernate一级缓存的特点:
当应用程序调用Session接口的save()、update()、saveOrUpdate时,如果Session缓存中没有相应的对象,Hibernate就会自动的把从数据库中查找的相对信息加入到一级缓存中去。
当调用Session接口的load()、get()方法,以及Query接口的list()、iterator()方法时,会判断缓存中是否存在该对象,有则返回,就不会查询数据库了,如果缓存中没有要查询的数据对象,再去数据库中查询对应对象,并添加到一级缓存中。
当调用Session的close()方法时,Session缓存会被清空。
下面我们还是以案例的形式来验证一级缓存的存在:
/** * load方法产生的一级缓存 */ @Test public void select(){ Session session = HibernateUtil1.opensession(); Transaction bt = session.beginTransaction(); //第一次查询oid为1l的数据 Customer customer2 = session.get(Customer.class, 1l); //第二次查询oid为1l的数据 Customer customer3 = session.get(Customer.class, 1l); //分别打印customer2和customer3 System.out.println(customer3); System.out.println(customer2); System.out.println(customer2==customer3); bt.commit(); session.close(); }
输出的结果为:![]()
结果分析:再第二次查询customer2时我们可以发现并没有打印select语句,因为customer2和customer1的数据对象是一样的,所以就直接从缓存取出相应的数据信息了,打印出“true”也证明了两者的地址值也是一样的。
我们再来看一下save()方法产生的一级缓存:
输出的结果为:/** * 插入新数据产生的一级缓存 */ @Test public void save(){ Session session = HibernateUtils.openSession(); Transaction tx = session.beginTransaction(); Customer customer = new Customer(); //设置插入的数据的oid和name值 customer.setCust_id(10l); customer.setCust_name("迪斯尼"); //插入数据 session.save(customer); //再次查询出新插入的数据 Customer customer2 = session.get(Customer.class, 10l); System.out.println(customer2); tx.commit(); session.close(); }
结果分析:由于save()方法将新插入的数据存入了一级缓存中,所以当再次查询数据时,就会直接从缓存中提取数据对象,不会查询数据库,从而没有打印select语句。
Hibernate的一级缓存
最新推荐文章于 2023-05-08 11:56:46 发布