码迷,mamicode.com
首页 > Web开发 > 详细

Hibernate查询缓存的利弊

时间:2015-03-21 11:23:13      阅读:173      评论:0      收藏:0      [点我收藏+]

标签:hibernate   缓存   

在使用hibernate二级缓存时适不适合开启查询缓存?

本人不建议使用查询缓存,因为查询缓存要求完全相同的查询sql语句才会起作用,所说的查询缓存是针对第二次查询时 sql语句与第一次sql语句完全相同 那么就可以从缓存中取数据而不去数据库中取数据了,在不启用查询缓存的情况下 每次的查询数据也会缓存到二级缓存的 只不过每次查询都会去查询数据库(不包括根据ID查询),启用查询缓存很麻烦 需要每次查询时 调用Query.setCacheable(true)方法才可以,如:List<OrgiData> orgiDatas = (List<OrgiData>) s.createQuery("from OrgiData").setCacheable(true).list(); 


因此建议将查询缓存设置为如下: 
hibernate.cache.use_query_cache=false 


还有就是最重要的一点:对于经常修改或重要的数据不宜进行缓存,因为多并发时会造成数据不同步的情况。

Hibernate查询缓存的利弊

标签:hibernate   缓存   

原文地址:http://blog.csdn.net/zeb_perfect/article/details/44513495

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!