`
lvhuiqing
  • 浏览: 244734 次
  • 性别: Icon_minigender_1
  • 来自: 沈阳
社区版块
存档分类
最新评论

Hibernate缓存机制(三)

 
阅读更多
<p>1,hibernate在查找数据的时候,会首先从一级缓存里面查找,再从二级缓存里面查找。</p>
<p>2,在缓存里找到的话,叫做“命中”。如果命中率过低的话,会导致使用二级缓存反而降低效率的问题。</p>
<p>3,如果想要观察二级缓存的命中率等信息,可以把统计信息打开</p>
<p> &lt;property name="generate_statistics"&gt;true&lt;/property &gt;</p>
<p> 设置完成后,可以打印出统计信息:</p>
<p> Statistics st=HibernateUtil.getSessionFactory().getStatistics();</p>
<p> System.out.println(st);</p>
<p>4,save()方法也会导致数据放入二级缓存,但是这个主键生成器有关系,如果是native的话,不会放入。如果是"hilo"的话,就会放入缓存</p>
<p>5,二级缓存存入和取出的方式跟一级缓存类似。</p>
<p>6,清除二级缓存里面的数据HibernateUtil.getSessionFactory().evict(User.class,id);一般不会需要。</p>
<p>7,缺省的,对于查询的数据的缓存,Hibernate会将其关掉,如果我们需要的话,我们需要手动的打开。</p>
<p> 例如 Query q=s.createQuery("from User where id="+id);</p>
<p> user=(User)q.uniqueResult();</p>
<p> q.setCacheable(true);</p>
<p> System.out.println(user.getName);</p>
<p>&lt;property name="cache.use_query_cache"&gt;true&lt;/property&gt;</p>

<p>之所以要这样麻烦,是因为查询时,命中率很低(只有两次query语句完全一致的时候,才会命中),所以通常打开是没有必要的。</p>
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics