hibernate二级缓存配置

  1. 二级缓存配置:   
  2.   
  3. 1、首先要打开二级缓存,在hibernate.cfg.xml中添加如下配置:   
  4. <property name="hibernate.cache.use_second_level_cache">true</property>  
  5.   
  6. 2、Hibernate的二级缓存使用第三方的缓存工具来实现,所以我们需要指定Hibernate使用哪个   
  7.    缓存工具。如下配置指定Hibernate使用EhCache缓存工具。   
  8. <property name="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</property>  
  9.   
  10. 3、Hibernate在默认情况下并不会对所有实体对象进行缓存,所以,我们需要指定缓存哪些对象,   
  11. 在实体对象的映射文件中(相应的<class>标签内部),添加如下配置:   
  12. <cache usage="read-only"/>  
  13.   
  14. usage="read-only"是“只读”缓存策略。   
  15.   
  16. 注意,这个<cache>标签只能放在<class>标签的内部,而且必须处在<id>标签的前面!!!   
  17. 这个<cache>标签放在哪些<class>标签下面,就说明会多这些类的对象进行缓存   
  18.   
  19. 4、对于第3步,有一个可选的方案是在hibernate.cfg.xml文件中指定哪些类的对象需要缓存,   
  20.    而不需要使用<cache>标签来指定。如:   
  21.    在hibernate.cfg.xml中添加如下配置:   
  22.    <class-cache class="com.bjsxt.hibernate.Classes" usage="read-only" />  
  23.      
  24.    注意,这个<class-cache>标签必须放在<mapping>标签的后面!!   















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);属性 

  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(); 
 } 
}

转:http://blog.csdn.net/wwxtu24/article/details/3936857

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值