配置Hibernate二级缓存

首先找到配置EHCahe二级缓存需要添加的jar包

hibernate-release-4.1.9.Final→lib→optional→ehcache→下的ehcache-core-2.4.3.jar和hibernate-ehcache-4.1.9.Final.jar还有slf4j-api-1.6.1.jar!

然后再从hibernate-release-4.1.9.Final→project→etc→把ehcache.xml复制到src目录下.把缓存.xml没用的都删了,留下最终:

<ehcache>

<!-- 缓存路径 -->

<diskStore path="E:\SecondCache"/>      //自己配置

<defaultCache

maxElementsInMemory="10000"

eternal="false"

timeToIdleSeconds="120"

timeToLiveSeconds="120"

overflowToDisk="true"

/>

</ehcache>

再在hibernate.cfg.xml里开启和配置缓存:

<!-- 开启二级缓存 -->

<property name="hibernate.cache.use_second_level_cache">true</property>

<!-- 高速缓存提供程序 -->

<property name="hibernate.cache.region.factory_class">

org.hibernate.cache.ehcache.EhCacheRegionFactory

</property>

最后在实体类的xml文件里设置缓存: <cache usage="read-write"/>

如:

<hibernate-mapping>

<class name="cn.jnit.bean.User" table="T_user">

<cache usage="read-write"/>

<id name="id">

<generator class="sequence">

</generator>

</id>

<property name="pwd"></property>

<property name="name"></property>

<one-to-one name="ud" class="cn.jnit.bean.UserDetail" cascade="all" ></one-to-one>

</class>

</hibernate-mapping>

如果查询的是集合的话:也需要在<SET>里设置:

<hibernate-mapping>

<class name="cn.jbit.bean.Dept" table="DEPT">

<cache usage="read-write" />

<id name="deptno">

<generator class="sequence"></generator>

</id>

<property name="dname"></property>

<property name="loc"></property>

<set name="emps" cascade="save-update" inverse="true" order-by="empno desc"

lazy="false">

<cache usage="read-only" />

<key column="deptno"></key>

<one-to-many class="cn.jbit.bean.Emp" />

</set>

</class>

</hibernate-mapping>.

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

如果配置文件里没有<SET>,不必设置,QUERY的查询语句优化的话,需要开启查询缓存→<!-- 开启查询缓存 -->

<property name="hibernate.cache.query_cache_factory">true</property>

下面是我一对一关系里测试的数据,切记:

不 是 Iterator<User> iterator=ses.createQuery(hql).setCacheable(true). list().iterator();

Iterator<User> iterator=ses.createQuery(hql).setCacheable(true).iterate();

Session ses=HibernateSessionFactory.getSession();

String hql="from User";

List<User> list = ses.createQuery(hql).setCacheable(true).list();

System.out.println(list.size());

HibernateSessionFactory.closeSession();

ses=HibernateSessionFactory.getSession();

Iterator<User> iterator = ses.createQuery(hql).setCacheable(true).iterate();

while (iterator.hasNext()) {

User user = (User) iterator.next();

System.out.println(user.getId());

}

ses.close();

时间: 2024-08-07 19:51:45

配置Hibernate二级缓存的相关文章

Hibernate学习11——配置Hibernate二级缓存

一.缓存的概念: 以空间换时间: 二.Hibernate缓存的分类: 前面我们讲的缓存都是session缓存:也叫一级缓存:get,load等缓存都是内置的,一级缓存: SessionFactory缓存,二级缓存: 这里以Class -- Student,1对多的关系(单向)来例子说明下: Class.java: package com.cy.model; public class Class { private int id; private String name; public int g

Hibernate ——二级缓存

一.Hibernate 二级缓存 1.Hibernate 二级缓存是 SessionFactory 级别的缓存. 2.二级缓存分为两类: (1)Hibernate内置二级缓存 (2)外置缓存,可配置的,可插拨的,外置缓存中的数据是数据库数据的复制. 3.二级缓存的并发访问策略 (1)两个并发的事务同时访问持久层的缓存的相同数据时,也有可能出现并发问题. (2)二级缓存可以设定以下 4 中并发访问策略,每一种对应一种事务隔离级别. 非严格读写(Nonstrict-read-write):不保证缓存

Hibernate二级缓存以及ehcache的搭建配置

前言 这次主要复习Hibernate的二级缓存的相关知识,配置以及使用.二级缓存主要采用第三方的ehcache,也将介绍ehcache缓存的相关配置属性以及在项目中的搭建,具体的项目查看下一篇的 Maven搭建SpringMVC+Hibernate项目详解 的文章.(之前使用过Hibernate的二级缓存,但是没自己搭建和研究过,现在花了半天时间搭建了一下,写下来供大家参考) 1.Hibernate二级缓存 Hibernate包括两个级别的缓存: 1.一级缓存:默认总是启用的session级别的

Hibernate二级缓存的使用

1启用Hibernate二级缓存 Hibernate二级缓存分为两部分,class缓存和查询缓存,其获取对象的方式有所不同,但两者也有联系,查询缓存必须以class缓存为基础才能起作用,否则只会使效率更低. 我们这里使用的二级缓存是通过ehcache第三方插件实现的. 1.1配置Hibernate.cfg.xml 启用class缓存: <property name="hibernate.cache.provider_class"> org.hibernate.cache.E

Hibernate学习---第十五节:hibernate二级缓存

1.二级缓存所需要的 jar 包 这三个 jar 包实在 hibernate 解压缩文件夹的 lib\optional\ehcache 目录下 2.配置 ehcache.xml <ehcache> <!-- 指定当缓存数据超出规定缓存大小的时候,超出的缓存数据写入到磁盘的位置 --> <diskStore path="D:/cache/tmp"/> <!-- maxInMemory - 允许在二级缓存中的持久化对象数量 eternal - 缓存

Ehcache 实现 Hibernate 二级缓存策略

1.条件查询的时候,总是发出一条select * from table_name where ....  (选择所有字段)这样的SQL语句查询数据库,一次获得所有的数据对象. 2.把获得的所有数据对象根据ID放入到第二级缓存中. 3.当Hibernate根据ID访问数据对象的时候,首先从Session一级缓存中查:查不到,如果配置了二级缓存,那么从二级缓存中查:查不到,再查询数据库,把结果按照ID放入到缓存. 4.删除.更新.增加数据的时候,同时更新缓存. Hibernate的二级缓存策略,是针

Hibernate(十六):Hibernate二级缓存(一)

Hibernate缓存 缓存(Cache):计算机领域非常通用的概念.它介于应用程序和永久性数据存储源(如磁盘上的文件或者数据库)之间,起作用是降低应用程序直接读取永久性数据存储源的频率,从而提高应用的运行性能.缓存中的数据是数据存储源中数据的拷贝.缓存的物理介质通常是内存. Hibernate中提供了两个级别的缓存 1)第一级别的缓存是Session级别的缓存,它是属于事务范围的缓存.这一级别的缓存由hibernate管理. 2)第二级别的缓存是SesssionFactory级别的缓存,它是属

hibernate二级缓存ehcache

<!-----------------hibernate二级缓存ehcache------------------------->hibernate配置 <prop key="hibernate.cache.use_query_cache">true</prop> <prop key="hibernate.cache.use_second_level_cache">true</prop> <prop

Hibernate 二级缓存 总结整理(转)

和<Hibernate 关系映射 收集.总结整理> 一样,本篇文章也是我很早之前收集.总结整理的,在此也发上来 希望对大家有用.因为是很早之前写的,不当之处请指正. 1.缓存:缓存是什么,解决什么问题? 位于速度相差较大的两种硬件/软件之间的,用于协调两者数据传输速度差异的结构,均可称之为 Cache(摘自Robbin的<缓存技术浅谈>).目的:让数据更接近于应用程序,协调速度不匹配,使访问速度更快.(请参考http://baike.baidu.com/view/907.htm 了