1:ehcache.xml的配置
<ehcache>
<!-- 当缓存超出最大值时 应该序列化到硬盘 的路径 -->
<diskStore path="f:/ehcache"/>
<!-- 这是默认的 -->
maxElementsInMemory="10000" 缓存中允许存放的最大对象的数量
eternal="false" 缓存中的数据是否为常量
timeToIdleSeconds="120" 存放数据钝化的时间
timeToLiveSeconds="120" 存放数据的生存时间
overflowToDisk="true"内存不足时是否启用磁盘缓存
diskPersistent="true" 表示当sessionFactory关闭的时候,是否清除硬盘上保存的对象的数据。
<!-- 这是自定义的 -->
<cache name="user"
maxElementsInMemory="1000"
eternal="false"
timeToIdleSeconds="300"
timeToLiveSeconds="600"
overflowToDisk="true"
diskPersistent="true"
/>
</ehcache>
2:hibernate.cfg.xml的配置
<!-- 二级缓存的实现类-->
<property name="cache.provider_class">org.hibernate.cache.EhCacheProvider</property>
<!-- 配合是否使用查询缓存 -->
<property name="cache.use_query_cache">true</property>
<!--
到底哪些持久化类需要启用二级缓存 usage是缓存同步访问策略,region表示使用的缓存区域,与ehcache中的配置要一致
如果不配置region,就表示使用默认的缓存区域
-->
<class-cache class="com.lovo.po.Pet" usage="read-write" region="user" />
3:测试类
session.createQuery("select p from Pet p")
.setCacheable(true) //启用
.setCacheRegion("user")
.list();
分享到:
相关推荐
本文将深入探讨Hibernate的一级缓存、二级缓存以及查询缓存,通过具体的实例来阐述它们的工作原理和使用方法。 首先,我们从一级缓存开始。一级缓存是Hibernate默认提供的缓存,它是每个Session级别的,也被称为...
在深入探讨Hibernate查询缓存之前,我们先了解一下Hibernate的基础概念。Hibernate是一个强大的Java持久化框架,它简化了数据库操作,提供了对象关系映射(ORM)功能。在Hibernate中,对象的状态分为瞬时态、持久态...
这包括选择合适的缓存提供商、设置缓存策略、决定哪些实体或查询结果应放入缓存等。开发者需要根据业务需求和系统负载进行权衡,以达到最佳的缓存效果。 ### 总结 Hibernate的一级缓存、二级缓存和查询缓存共同...
例如,如果在没有启用查询缓存时,使用`load()`方法获取的单个持久化对象会被缓存,但若想缓存`findAll()`, `list()`, `Iterator()`, `createQuery()`, `createCriteria()`等方法获取的结果集,必须设置`hibernate....
文档"Hibernate_二级缓存总结 开发技术 - Java.doc"可能详细阐述了如何配置和使用Hibernate的二级缓存,包括配置文件的设置、缓存提供者的选用、实体和集合的缓存配置,以及实战中的优化技巧。阅读该文档将有助于...
总的来说,尽管Hibernate的使用场景可能不像过去那么广泛,但其提供的对象关系映射、缓存机制和查询优化策略仍然是理解现代数据库操作和Java开发中的宝贵知识。了解并掌握这些技术,可以帮助开发者编写出更高效、更...
Hibernate缓存机制是提高应用程序性能的关键特性,尤其是在频繁与数据库交互的应用中。缓存通过减少对物理数据库的直接访问次数,显著提升了数据读取和写入的速度。这主要是因为从缓存中读取数据比从数据库中获取更...
1. **开启查询缓存**:在配置文件中开启查询缓存支持,并在查询时设置`setCacheable(true)`。 2. **编写测试代码**:例如,在测试代码中,当执行两次相同的查询时,第二次查询将直接从查询缓存中获取结果,而不是...
【Hibernate缓存深入详解】 在Java的持久化框架Hibernate中,缓存机制是提升系统性能的关键因素。它位于Hibernate应用和数据库之间,减少了对数据库的直接访问,从而提高了应用程序的运行速度。缓存中存储的是...
在 Hibernate 中,二级缓存和查询缓存是提高应用性能的重要机制。下面将详细介绍如何开启并理解这两个缓存机制。 ### 1. 一级缓存与二级缓存 #### 1.1 一级缓存 一级缓存是 Hibernate 内置的 Session 缓存,它是每...
### Hibernate缓存技术研究 #### 一、引言 Hibernate是一种强大的对象-关系映射(Object-Relational Mapping,简称ORM)工具,主要用于Java环境下的应用程序。它能够将应用程序中的对象模型映射到关系型数据库的表...
Hibernate缓存可以针对实体类、集合类、SQL查询结果等设置不同的缓存区域。根据业务需求,可以自定义缓存策略,为不同类型的对象设置不同的缓存过期时间。 **六、缓存同步** 为了保证多线程环境下的数据一致性,...
启用查询缓存需要在配置中开启,并且在Ehcache的配置文件中为特定查询设置缓存策略。 总结来说,Hibernate的二级缓存是提升性能的关键手段,通过合理配置和使用,可以有效减少数据库交互,提高应用响应速度。需要...
综上所述,Hibernate缓存机制是提升应用性能的重要手段,通过合理配置缓存策略、优化查询方式、管理数据库连接以及实施有效的监控和调优措施,可以显著提高Hibernate应用的运行效率和用户体验。然而,缓存的使用并非...
Ehcache.xml文件就是用于配置Ehcache作为二级缓存的配置文件,其中会包含缓存策略、大小限制、过期策略等设置。 **查询缓存**: 查询缓存主要用于存储查询结果,当执行相同的HQL或SQL查询时,如果查询结果已存在于...
这种实现方式使得在后续查询相同ID时可以直接从缓存中获取,避免了数据库的再次查询。 #### 五、二级缓存的实现细节 - **外置缓存的实现**:由于二级缓存是可配置的,因此可以根据具体需求选择不同的实现方案。...
管理Hibernate的缓存缓存 管理Hibernate的缓存缓存
Hibernate 是一个流行的对象关系映射(ORM)框架,它允许Java...通过理解Hibernate缓存和事务管理,以及如何有效地执行查询,开发者可以创建高效、健壮的Java应用程序,降低与数据库交互的复杂性,同时提升系统性能。