Hibernate中一级缓存、二级缓存及查询缓存

转自:http://blog.csdn.net/humao84229247/archive/2010/05/04/5556770.aspx

 

一、 一级缓存

1.         一级缓存只缓存整个对象,不能缓存对象属性;

2.         一级缓存是Session级的缓存,不能跨多个Session对象来使用;

3.         Session的load/get方法支持一级缓存的读和写;

4.         Query的list接口只支持一级缓存的写入,不能从一级缓存中读出对象。list接口加载对象要发出SQL;

5.         Query的iterate接口既支持一级缓存的写入,也能从一级缓存中读取对象(如果有的话)。每次用iterate接口查询对象,都要先发SQL加载查询对象的id列表。如果需要用到某个对象,则根据该对象的id从一级缓存中查询,有则直接加载,没有则发出SQL从数据库加载(这时会出现1+N问题)。

6.         Session的save方法会将save的对象放入一级缓存中,因此如果要save大批对象,则应该要及时清空一级缓存,可以采用Session的clear()方法。

7.         一级缓存是hibernate 默认使用的,无需配置即可使用。

 

二、  二级缓存

1.       二级缓存也是只能缓存整个对象,不能缓存对象属性,而且对load/get方法、list/iterate方法的在使用上跟一级缓存一样。

2.       与一级缓存不同,二级缓存是SessionFactory级的缓存,它允许多个Session对象之间共用。

3.       使用二级缓存前必须进行一些准备步骤(以EhCache为例):

(1)    需要有EhCache的xml配置文件(设置EhCache的“缓存对象最大数目”、“对象是否不失效”、“对象允许的空闲时间”、“对象的生存时间”及“对象数目超额时是否缓存至磁盘”);

(2)    在总配置文件hibernate.cfg.xml中启用二级缓存(默认开启,无需显示配置):

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

(3)    指定二级缓存的供应商:

<property name="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</property>

(4)    指定需要缓存的类及缓存方式(可在hibernate.cfg.xml或对应的类的.hbm.xml中配置):

在hibernate.cfg.xml中配置:

<class-cache usage="read-only" class="my.Student"/>

在Student.hbm.xml中配置(必须在配置id前完成):

<cache usage="read-only"/>

(5)    可以通过Session动态设置是否允许对二级缓存进行读和写,方法是:session.setCacheMode(CacheMode.GET)和session.setCacheMode(CacheMode.PUT)

(6)    SessionFactory的evit()会将一个对象逐处二级缓存。

 

三、  查询缓存

查询缓存是专为Query的list方法设计的。对于iterate()方法,无论是查询对象属性还是对象本身,查询缓存用与不用都没有区别!

1.用查询缓存查询属性:

(1)    查询缓存必须要在hibernate.cfg.xml中显示启用:

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

(2)    在代码中如果要用到查询缓存(无论是写还是读缓存),都要进行开启操作,可通过Query的setCacheable(true)方法开启;

(3)    查询缓存的生命周期与Session无关(可以跨Session查询),当查询关联的表发生改变,那么查询缓存的生命周期结束(delete、update、modify)

(4)    开启查询缓存,并用Query查询对象的属性(可以是一个或多个)时,采用Query的list方法可以把得到的属性集合写入查询缓存中。如果查询缓存已经有了该对象的属性,那么就不会发出SQL而直接从查询缓存中取出来;

2.用查询缓存查询对象:

(5)    如果开启查询缓存并通过list接口查询对象,在首次查询时会发出SQL从数据库中获取对象,同时将对象的id列表放入查询缓存中;如果再次用查询缓存查询对象,则会根据该对象的id发出SQL从数据库中加载对象(这时会发出N条SQL语句)

(6)    如果同时开启查询和二级缓存,那么(5)中就不会发出N条SQL语句了,而是直接从二级缓存中加载。(此时的list接口有了读二级缓存的能力了!!!)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值