Hibernate中二级缓存的配置和使用
创始人
2024-04-01 03:52:21
0

(一)Hibernate的二级缓存策略的一般过程如下:
 
1) 条件查询的时候,总是发出一条select * from table_name where …. (选择所有字段)这样的SQL语句查询数据库,一次获得所有的数据对象。

2) 把获得的所有数据对象根据ID放入到第二级缓存中。

3) 当Hibernate根据ID访问数据对象的时候,首先从Session一级缓存中查;查不到,如果配置了二级缓存,那么从二级缓存中查;查不到,再查询数据库,把结果按照ID放入到缓存。

4) 删除、更新、增加数据的时候,同时更新缓存。
 
Hibernate的二级缓存策略,是针对于ID查询的缓存策略,对于条件查询则毫无作用。为此,Hibernate提供了针对条件查询的Query Cache。

(二)什么样的数据适合存放到第二级缓存中?

1 很少被修改的数据

2 不是很重要的数据,允许出现偶尔并发的数据

3 不会被并发访问的数据

4 参考数据,指的是供应用参考的常量数据,它的实例数目有限,它的实例会被许多其他类的实例引用,实例极少或者从来不会被修改。

(三)不适合存放到第二级缓存的数据?

1 经常被修改的数据

2 财务数据,绝对不允许出现并发

3 与其他应用共享的数据。

实践部分:

使用EhCache配置二级缓存
 
配置准备:
 
1)把ehcache-1.2.3.jar加入到当前应用的classpath中。

2)在hibernate.cfg.xml文件中加入EhCache缓存插件的提供类。

  1.    
  2.    
  3.     org.hibernate.cache.EhCacheProvider   
  4.   

3)挎贝ehcache.xml文件到类路径(项目工程的src目录下),这个文件在Hibernate安装目录的etc下。
 
配置步骤:
 
Hibernate允许在类和集合的粒度上设置第二级缓存。在映射文件中,元素都有一个子元素,这个子元素用来配置二级缓存。
示例:以category(产品类别)和product(产品)的映射为例:

1) 修改要配置缓存的那个持久化类的对象关系映射文件:

Category.hbm.xml

 

  1.    
  2. "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">   
  3.    
  4.        
  5.                     配置缓存,必须紧跟在class元素后面   
  6.             对缓存中的Category对象采用读写型的并发访问策略   
  7.         -->   
  8.           
  9.          
  10.           
  11.               
  12.               
  13.           
  14.           
  15.           
  16.          
  17.           
  18.               
  19.           
  20.          
  21.           
  22.               
  23.           
  24.          
  25.           
  26.               
  27.               
  28.              
  29.               
  30.               
  31.           
  32.          
  33.        
  34.    
  35.  

Product.hbm.xml

  1.    
  2. "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">   
  3.    
  4.        
  5.          
  6.           
  7.          
  8.           
  9.               
  10.               
  11.           
  12.           
  13.           
  14.          
  15.           
  16.               
  17.           
  18.          
  19.           
  20.               
  21.           
  22.          
  23.           
  24.               
  25.           
  26.          
  27.           
  28.               
  29.           
  30.          
  31.                        column="categoryId"   
  32.                class="org.qiujy.domain.cachedemo.Category"   
  33.                cascade="save-update"   
  34.                 not-null="true">   
  35.            
  36.          
  37.        
  38.    

2)编辑ehcache.xml文件:

  1.    
  2.        
  3.             maxElementsInMemory="10000"   
  4.         eternal="false"   
  5.         timeToIdleSeconds="120"   
  6.         timeToLiveSeconds="120"   
  7.         overflowToDisk="true"     
  8.         />   
  9.           
  10.        
  11.             maxElementsInMemory="100"   
  12.         eternal="true"   
  13.         timeToIdleSeconds="0"   
  14.         timeToLiveSeconds="0"   
  15.         overflowToDisk="false"   
  16.         />   
  17.           
  18.         
  19.              maxElementsInMemory="500"   
  20.         eternal="false"   
  21.         timeToIdleSeconds="300"   
  22.         timeToLiveSeconds="600"   
  23.         overflowToDisk="true"   
  24.         />   
  25.           
  26.             maxElementsInMemory="500"   
  27.         eternal="false"   
  28.         timeToIdleSeconds="300"   
  29.         timeToLiveSeconds="600"   
  30.         overflowToDisk="true"   
  31.         />   
  32.       
  33.    

在Spring托管的Hibernate中使用二级缓存 1.在spring的配置文件中,hibernate部分加入 xml 代码 org.hibernate.cache.EhCacheProvider true 2.为HBM表设置cache策略 xml 代码 3.在DAO中,调用find方法查询之前,设置使用缓存 Java代码 getHibernateTemplate().setCacheQueries(true); 补充: 如果不设置“查询缓存”,那么hibernate只会缓存使用load()方法获得的单个持久化对象,如果想缓存使用findall()、list()、Iterator()、createCriteria()、createQuery()等方法获得的数据结果集的话,就需要设置 hibernate.cache.use_query_cache true 才行。

 

【编辑推荐】

  1. Hibernate查询方法之探析
  2. Hibernate的性能优化
  3. 浅谈HibernateTemplate类的使用
  4. Hibernate一对多,多对一,多对多,一对一关系汇总
  5. 关于Struts+Hibernate分页的问题

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...