配置Hibernate二级缓存

 

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

hibernate-release-4.1.9.Final→liboptional→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();

转载于:https://www.cnblogs.com/345214483-qq/p/4114695.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值