当前位置:天才代写 > tutorial > JAVA 教程 > Hibernate+ehcache二级缓存技能

Hibernate+ehcache二级缓存技能

2017-11-10 08:00 星期五 所属: JAVA 教程 浏览:418

副标题#e#

1、首先配置EhCache,成立设置文件ehcache.xml,默认的位置在class-path,可以放到你的src目次下:

<?xml version="1.0" encoding="UTF-8"?>
<ehcache>
  <diskStore path="java.io.tmpdir"/>
   <defaultCache
    maxElementsInMemory="10000" <!-- 缓存最大数目 -->
    eternal="false" <!-- 缓存是否耐久 -->
    overflowToDisk="true" <!-- 是否生存到磁盘,当系统当机时-->
    timeToIdleSeconds="300" <!-- 当缓存闲置n秒后销毁 -->
    timeToLiveSeconds="180" <!-- 当缓存存活n秒后销毁-->
    diskPersistent="false"
    diskExpiryThreadIntervalSeconds= "120"/>
</ehcache>

2、在Hibernate设置文件中配置:

<!-- 配置Hibernate的缓存接口类,这个类在Hibernate包中 -->
<property name="cache.provider_class">org.hibernate.cache.EhCacheProvider</property>
  <!-- 是否利用查询缓存 -->
  <property name="hibernate.cache.use_query_cache">true</property>
   假如利用spring挪用Hibernate的sessionFactory的话,这样配置:
   <!--HibernateSession工场打点 -->
    <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
    <property name="dataSource">
     <ref bean="datasource" />
    </property>
    <property name="hibernateProperties">
    <props>
     <prop key="hibernate.dialect">org.hibernate.dialect.Oracle9Dialect</prop>
     <prop key="connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</prop>
     <prop key="hibernate.show_sql">true</prop>
     <prop key="hibernate.cache.use_query_cache">true</prop>
     <prop key="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</prop>
    </props>
  </property>
  <property name="mappingDirectoryLocations">
   <list>
    <value>/WEB-INF/classes/cn/rmic/manager/hibernate/</value>
   </list>
  </property>
</bean>

说明一下:假如不配置“查询缓存”,那么hibernate只会缓存利用load()要领得到的单个耐久化工具,假如想缓存利用findall()、list()、Iterator()、createCriteria()、createQuery()等要领得到的数据功效集的话,就需要配置

hibernate.cache.use_query_cache true 才行

3、在Hbm文件中添加<cache usage="read-only"/>

4、假如需要“查询缓存”,还需要在利用Query或Criteria()时配置其setCacheable(true);属性


#p#副标题#e#

5、实践出真知,给一段测试措施,假如乐成的话第二次查询时不会读取数据库

package cn.rmic.hibernatesample;
import java.util.List;
import org.hibernate.CacheMode;
import org.hibernate.Criteria;
import org.hibernate.Query;
import org.hibernate.Session;
import cn.rmic.hibernatesample.hibernate.HibernateSessionFactory;
import cn.rmic.manager.po.Resources;
public class testCacheSelectList ...{
  /** *//**
  * @param args
  */
  public static void main(String[] args) ...{
   // TODO Auto-generated method stub
   Session s=HibernateSessionFactory.getSession();
   Criteria c=s.createCriteria(Resources.class);
   c.setCacheable(true);
   List l=c.list();
   // Query q=s.createQuery("From Resources r")
   // .setCacheable(true)
   // .setCacheRegion("frontpages") ;
   // List l=q.list();
   Resources resources=(Resources)l.get(0);
   System.out.println("-1-"+resources.getName());
   HibernateSessionFactory.closeSession();
   try ...{
    Thread.sleep(5000);
   } catch (InterruptedException e) ...{
    // TODO Auto-generated catch block
    e.printStackTrace();
   }
   s=HibernateSessionFactory.getSession();
   c=s.createCriteria(Resources.class);
   c.setCacheable(true);
   l=c.list();
   // q=s.createQuery("From Resources r").setCacheable(true)
   // .setCacheRegion("frontpages");
   // l=q.list();
   resources=(Resources)l.get(0);
   System.out.println("-2-"+resources.getName());
   HibernateSessionFactory.closeSession();
  }
}

 

    关键字:

天才代写-代写联系方式