首页 > Web开发 > 详细

Hibernate查询缓存的利弊

时间:2015-03-21 11:20:45      阅读:371      评论:0      收藏:0      [点我收藏+]

在使用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查询缓存的利弊

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

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!