<b>Hibernate二级缓存攻略</b>[Java编程]
本文“<b>Hibernate二级缓存攻略</b>[Java编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
很多人对二级缓存都不太理解,大概是有错误的熟习,我一向想写一篇文章介绍一下hibernate的二级缓存的,本日终于不由得了.
我的经验主要来自hibernate2.1版本,基本原理和3.0、3.1是一样的,请谅解我的顽固不化.
hibernate的session供应了一级缓存,每个session,对同一个id举行两次load,不会发送两条sql给数据库,但是session关闭的时刻,一级缓存就失效了.
二级缓存是SessionFactory级别的全局缓存,它底下可以利用差别的缓存类库,比方ehcache、oscache等,需求设置hibernate.cache.provider_class,我们这里用ehcache,在2.1中就是 hibernate.cache.provider_class=net.sf.hibernate.cache.EhCacheProvider假如利用查询缓存,加上hibernate.cache.use_query_cache=true
缓存可以简单的当作一个Map,通过key在缓存里面找value.
Class的缓存
关于一条记录,也就是一个PO来说,是按照ID来找的,缓存的key就是ID,value是POJO.无论list,load还是iterate,只要读出一个对象,城市填充缓存.但是list不会利用缓存,而iterate会先取数据库select id出来,然后一个id一个id的load,假如在缓存里面有,就从缓存取,没有的话就去数据库load.假定是读写缓存,需求设置:
<cache usage="read-write"/>
假如你利用的二级缓存实现是ehcache的话,需求配置ehcache.xml
<cache name="com.xxx.pojo.Foo" maxElementsInMemory="500" eternal="false" timeToLiveSeconds="7200" timeToIdleSeconds="3600" overflowToDisk="true" />
此中eternal表示缓存是不是永久不超时,timeToLiveSeconds是缓存中每个元素(这里也就是一个POJO)的超不时间,假如eternal="false",超越指定的时间,这个元素就被移走了.timeToIdleSeconds是发呆时间,是可选的.当往缓存里面put的元素超越500个时,假如overflowToDisk="true",就会把缓存中的部份数据保存在硬盘上的暂时文件里面.
每个需求缓存的class都要这样配置.假如你没有配置,hibernate会在启动的时刻告诫你,然后利用defaultCache的配置,这样多个class会同享一个配置.
当某个ID通过hibernate改正时,hibernate会知道,于是移除缓存.
这样大家大概会想,一样的查询条件,第一次先list,第二次再iterate,便可以利用到缓存了.实际上这是很难的,因为你无法判断什么时刻是第一次,并且每次查询的条件普通是不一样的,假定数据库里面有100条记录,id从1到100,第一次list的时刻出了前50个id,第二次iterate的时刻却查询到30至70号id,那么30-50是从缓存里面取的,51到70是从数据库取的,共发送1+20条sql.所以我一向认为iterate没有什么用,老是会有1+N的问题.
(题外话:有说法说大型查询用list会把整个后果集装入内存,很慢,而iterate只select id对比好,但是大型查询老是要分页查的,谁也不会真的把整个后果集装进来,假定一页20条的话,iterate共需求履行21条语句,list固然挑选若干字段,比iterate第一条select id语句慢一些,但只有一条语句,不装入整个后果集hibernate还会按照数据库方言做优化,比方利用mysql的limit,整体看来应当还是list快.)
假如想要对list大概iterate查询的后果缓存,就要用到查询缓存了
以上是“<b>Hibernate二级缓存攻略</b>[Java编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |