hibernate配置缓存查询

       

[c-sharp] view plain copy print ?
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <ehcache>
  3. <defaultCache maxElementsInMemory="10000" eternal="false"
  4. timeToIdleSeconds="120" timeToLiveSeconds="120" overflowToDisk="true"
  5. diskPersistent="false" diskExpiryThreadIntervalSeconds="120" />
  6. <cache name="org.hibernate.cache.StandardQueryCache"
  7. maxElementsInMemory="50" eternal="false" timeToIdleSeconds="1800"
  8. timeToLiveSeconds="3600" overflowToDisk="true" />
  9. <cache name="org.hibernate.cache.UpdateTimestampsCache"
  10. maxElementsInMemory="5000" eternal="true" overflowToDisk="true" />
  11. <cache name="myCacheRegion" maxElementsInMemory="10" eternal="false"
  12. timeToIdleSeconds="3600" timeToLiveSeconds="7200" overflowToDisk="true" />
  13. </ehcache>

在hibernate配置文件中或spirng管理hibernate类当中加入:

[c-sharp] view plain copy print ?
  1. <property name="cache.use_query_cache">true</property>
  2. <property name="cache.use_second_level_cache">true</property>
  3. <property name="cache.provider_class">
  4. org.hibernate.cache.EhCacheProvider
  5. </property>

Dao中加入如下代码就能使用查询缓存了

Query q = this.getSession(false).createQuery(hql).setCacheable(true);

忘了补充一点:查询缓存是针对相同条件的查询和全体查询,而二级缓存是针对主键查询。

如果同时需要启动二级缓存又要启动查询缓存, 希望是同时同步的,如果不同步,假设只有二级缓存而没有查询缓存还可以,

但只有查询缓存没有二级缓存,hibernate会把查询结果再用主键查找一次,这样就加大了数据库的交互

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值