JPA 2.0 Vs Hibernate:缓存方法的差异(二)

转自:http://developer.51cto.com/art/201007/211328.htm


【51CTO独家编译】在前文中我们把JPA 2.0缓存原理进行了简单的介绍,本文将为大家介绍一下Hibernate缓存原理。(51CTO编辑特别推荐专题:Hibernate应用开发教程

Hibernate缓存原理

Hibernate也设有两个级别的缓存:第一级和第二级缓存。第一级缓存是存储在一个特定时域实例里的查询结果,而第二级缓存则是与SessionFactory实例相关联。

Hibernate的默认使用的第一级缓存来存储每一此运算的对象。 Hibernate的二级缓存是由SessionFactory支持,根据访问对象的应用水平来调用访问数据库需要的对象次数,从而减少了访问次数。Hibernate的缓存不是通过储存存储对象本身的实例来实现的。

Hibernate 3.0支持以下四个开源项目的第二级缓存实现:

◆EHCache (org.hibernate.cache.EhCacheProvider) -- Default

◆OSCache (org.hibernate.cache.OSCacheProvider)

◆SwarmCache (org.hibernate.cache.SwarmCacheProvider)

◆JBoss TreeCache (org.hibernate.cache.TreeCacheProvider)

第二级缓存可以启用分别设置属性hibernate.cache.use_second_level_cache为正确或错误。这里是一个设置实例:

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

你可以选择在hibernate.cfg.xml文件里的hibernate.cache.provider_class属性应用进行设置,这里是另一个设置实例:

 
 
  1. <property name="hibernate.cache.provider_class"> 
  2. org.hibernate.cache.EhCacheProvider  
  3. </property> 
  4.  

您也可以在类级层或集合层通过设置在映射文件作为<cache>组成部分启用缓存:

 
 
  1. <cache usage="read-only" region="regionName" include="all"/> 
  2.  

这里有一个在上面的代码中的组成部分:

◆指定缓存策略的使用情况。

◆指定二级缓存区域。

◆包括是一个可选属性(一般情况下为默认设置),如果数据不常使用可以取消缓存。

您还可以通过设置hibernate.cfg.xml文件中的<class-cache>和<collection-cache> 内容配置为缓存,在一个单独的EhCache配置文件(ehcache.xml)和项目的根目录里启用缓存。

您可以执行的缓存是同一组的参数经常使用的查询缓存。查询缓存设置为false默认情况下,您可以启用hibernate.cfg.xml文件中加入下面的属性:

 
 
  1. <property name="hibernate.cache.use_query_cache">true</property> 
  2.  

此查询添加StandardQueryCache和UpdateTimestampsCache,分别为查询缓存的结果和最新更新的时间表。查询结果可以通过调用缓存特定的setCacheable查询。

Hibernate 3.5缓存

Hibernate 3.5缓存策略与Hibernate的缓存策略是相同的,同时添加了在Hibernate 3.2和Hashtable没有的某些如JBoss Cache 2、JBoss Cache的1.x中缓存策略。

Hibernate 3.5另一个重大进步是Infinispan作为另一个二级缓存标准加入。Infinispan是一个开源、可扩展的数据网格平台,公开了JCache(支持JSR-107)兼容的缓存接口。 Infinispan提供了更高程度的并发性,因为Infinispan使用一个专门的数据结构,而不是仅仅捆绑到Java,同时它也支持PHP,Python和Ruby等。

结论

在本文中,我们比较的JPA 2.0缓存在Hibernate的缓存。通过引入新的缓存功能,促进标准化,JPA的2.0做了很多工作使得开发更容易。不过,因为所有的功能都有了很长时间的支持,Hibernate是在许多方面遥遥领先。



转自:http://developer.51cto.com/art/201007/211328.htm

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值