Hibernate二级缓存攻略

http://tech.ddvip.com   2006年11月20日    社区交流

本文详细介绍Hibernate二级缓存攻略

query.setCacheable(true);//激活查询缓存
query.setCacheRegion("myCacheRegion");//指定要使用的cacheRegion,可选

  第二行指定要使用的cacheRegion是myCacheRegion,即你可以给每个查询缓存做一个单独的配置,使用setCacheRegion来做这个指定,需要在ehcache.xml里面配置它:

<cache name="myCacheRegion" maxElementsInMemory="10" eternal="false" timeToIdleSeconds="3600" timeToLiveSeconds="7200" overflowToDisk="true" />

  如果省略第二行,不设置cacheRegion的话,那么会使用上面提到的标准查询缓存的配置,也就是:net.sf.hibernate.cache.StandardQueryCache

  对于查询缓存来说,缓存的key是根据hql生成的sql,再加上参数,分页等信息(可以通过日志输出看到,不过它的输出不是很可读,最好改一下它的代码)。

  比如hql:

from Cat c where c.name like ?

  生成大致如下的sql:

select * from cat c where c.name like ?

  参数是"tiger%",那么查询缓存的key*大约*是这样的字符串(我是凭记忆写的,并不精确,不过看了也该明白了):

select * from cat c where c.name like ? , parameter:tiger%

  这样,保证了同样的查询、同样的参数等条件下具有一样的key。

  现在说说缓存的value,如果是list方式的话,value在这里并不是整个结果集,而是查询出来的这一串ID。也就是说,不管是list方法还是iterate方法,第一次查询的时候,它们的查询方式很它们平时的方式是一样的,list执行一条sql,iterate执行1+N条,多出来的行为是它们填充了缓存。但是到同样条件第二次查询的时候,就都和iterate的行为一样了,根据缓存的key去缓存里面查到了value,value是一串id,然后在到class的缓存里面去一个一个的load出来。这样做是为了节约内存。

来源:JAVAEYE    作者:AreYouOK    责编:豆豆技术应用

正在加载评论...