hibernate 有两种级别的缓存
一级缓存:指的是Session的缓存,所有使用同一个Session通过get或load查询的数据,都会保存在缓存中,下次再查询时,先从缓存中查找,如果找到,则不会再查询数据库,当Session关闭时,自动销毁。一般开发中不会使用,因为Session需要关闭。
二级缓存:保存在SessionFactory中,因此可以多个Session共同使用,二级缓存需要第三方的支持。可以使用oscache、 ehcache之类缓存支持。默认Hibernate中加入的为ehcache缓存,这些缓存数据在一定时间后或SessionFactory销毁时自动销毁。
1、在需要使用缓存查询的映射文件中,加入使用缓存的配置
<cache usage="read-only"/>
<id name="id" type="java.lang.Integer">
<column name="id" />
<generator class="native" />
</id>
其中usage表示使用缓存的模式,默认为read-only,可以使用以下4种,其中第4种已经不使用了:
read-only:缓存为只读,缓存中的数据不可以被修改,在数据查询要求不严格时使用,而且数据库数据改变的不多。
read-write:可以读写的,当数据库中数据修改时,同时对缓存中的数据进行修改,数据准确性很高,但如果频繁修改,性能相对比较低。
nonstrict-read-write:不严格的可读写模式,不是当数据库中数据修改就立刻修改缓存中的数据,而是一定时间后,对数据库和缓存进行比较,如果有数据不同,则进行数据同步。
transactional:事务处理的方式,但目前read-write已经支持了事务操作,因此该模式已经不使用了。
2、在src下加入ehcache.xml配置文件
需要在src下加入ehcache.xml配置文件,该文件可以在hibernate开发包hibernate-3.2\etc中查找到
<ehcache>
<!-- 表示缓存文件所保存的临时路径,java.io.tmpdir表示JDK所临时保存文件的路径 -->
<diskStore path="java.io.tmpdir"/>
<!--
以下为默认缓存配置,如果没有进行单独的配置,使用该配置进行缓存的保存:
maxInMemory - 设置内存中可以创建pojo数据的最大数量(针对一个pojo)
eternal - 设置缓存中的数据是否永久存在.如果为true, 当超过时间后,数据也不销毁.
timeToIdleSeconds - 设置从缓存对象创建后经过多长时间自动销毁. 只有当eternal为false时才可以使用. 单位为秒
timeToLiveSeconds - 设置缓存对象经过一次查询后,多长时间不再被查询后自动销毁(闲置时间).
overflowToDisk - 如果为true,则当数据数量超出范围后(InMemory中的范围)后,是否保存到硬盘上(保存的位置在上面的diskStore中定义).
-->
<defaultCache
maxElementsInMemory="10000"
eternal="false"
timeToIdleSeconds="600"
timeToLiveSeconds="120"
overflowToDisk="true"
/>
<!--
也可以自定义某一个类所使用的设置
name表示该类的包.类名
-->
<cache name="org.liky.pojo.Area"
maxElementsInMemory="20000"
eternal="false"
timeToIdleSeconds="1200"
timeToLiveSeconds="300"
overflowToDisk="true"
/>
</ehcache>
3、修改实现类(使用二级缓存)
修改实现类,实现类中需要为query或criteria设置打开缓存查询属性
public List<Area> findAll() throws Exception {
// TODO Auto-generated method stub
Criteria c = this.instance.getConnnection().createCriteria(Area.class);
// 设置使用缓存
c.setCacheable(true);
return c.list();
}
参考文章:http://zisefeiniao.iteye.com/blog/396704
分享到:
相关推荐
Hibernate二级缓存是一种提高应用程序性能的技术,它将数据存储在SessionFactory级别的缓存中,使得数据可以在不同的Session之间共享。这与一级缓存(Session级别)不同,一级缓存仅存在于单个Session生命周期内,当...
Hibernate 二级缓存是针对SessionFactory级别的全局缓存,与一级缓存(Session级别)不同,一级缓存只在单个Session生命周期内有效。二级缓存则允许不同Session之间共享数据,提高了数据访问效率,减少了对数据库的...
Hibernate 二级缓存是一种高效的数据存储机制,它能够显著提升Web应用的性能,尤其是在处理大量数据流动时。缓存的主要目标是减少应用与数据库之间的交互次数,从而降低延迟并减轻数据库服务器的压力。在Hibernate...
Hibernate 二级缓存
在这个"hibernate二级缓存实例"中,我们将深入探讨二级缓存的原理、配置以及在实际项目中的应用。 首先,我们需要了解一级缓存和二级缓存的区别。一级缓存是Session级别的,每个Session都有自己的一级缓存,用于...
**hibernate二级缓存详解** Hibernate作为Java领域中广泛使用的对象关系映射(ORM)框架,极大地简化了数据库操作。然而,在处理大量数据时,性能优化显得尤为重要,这就是二级缓存的作用。本文将深入探讨Hibernate...
**Hibernate 二级缓存总结整理** 在Java的持久化框架中,Hibernate是一个广泛使用的ORM(对象关系映射)工具,它极大地简化了数据库操作。在处理大数据量或高并发的场景下,为了提高性能和减少数据库负载,...
Hibernate二级缓存是Java开发中使用Hibernate框架进行数据持久化时优化性能的一种重要技术。它在一级缓存(Session级别的缓存)的基础上,提供了一个全局的、跨会话的数据存储层,可以显著减少对数据库的访问,从而...
二级缓存是 Hibernate 缓存策略的一部分,它在应用程序的多个会话之间共享数据,进一步优化了数据库访问效率。 二级缓存分为以下关键知识点: 1. **一级缓存与二级缓存的区别**: - 一级缓存:每个 Hibernate ...
本篇文章将深入探讨Hibernate二级缓存的概念、工作原理以及如何在实际项目中设置和使用。 **一、二级缓存概念** 一级缓存是每个Hibernate Session内部的一个内存区域,用于存储Session期间的操作对象。当Session...
本篇将详细介绍Hibernate二级缓存的概念、作用以及所需jar包的作用。 一、Hibernate二级缓存概念 Hibernate的一级缓存是指Session级别的缓存,每个Session内部都有一个一级缓存,用于存储实体对象,当Session关闭时...
本篇文章将深入探讨Hibernate的二级缓存机制,以及如何进行一级缓存与二级缓存的同步,同时还会介绍二级缓存的配置文件设置。 一级缓存是Hibernate默认提供的缓存,每个SessionFactory实例都有一个一级缓存。当对象...