hibernate一级缓存,二级缓存和查询缓存
2016-04-12 08:31
253 查看
一级缓存 (必然存在)
session里共享缓存,伴随session的生命周期存在和消亡:
1. load查询实体支持一级缓存
2. get查询实体对象也支持
3. save保存的实体对象会缓存在一级缓存
4. clear evict会清除session缓存
5. save巨大数据,每20个数据,一般flush运行sql将数据持久化然后clear缓存。防止内存溢出。save放最后。
6. iterate使用一级缓存(creatQuery中的查询实体对象list会使用一级缓存,查询对象实体属性不会使用)
二级缓存
进程级别的缓存或sessionFactory缓存,能够被session共享,伴随sessionFactory存在和消亡。
查询缓存
仅仅缓存普通属性结果集的缓存,实体对象仅仅缓存id
生命周期:当查询关联的表发生改动,就结束。跟二级缓存无关。须要显示启用,query.setCacheable(true)而且仅仅对list起作用,对iterator不起作用。它不使用查询缓存。
抓取策略
1. 查询抓取fetch=join. 把外键关联的对象也取出来,一条SQL,会使lazy失效,提高效率,能够配置或原生SQL
2. Subselect 子查询策略
session里共享缓存,伴随session的生命周期存在和消亡:
1. load查询实体支持一级缓存
2. get查询实体对象也支持
3. save保存的实体对象会缓存在一级缓存
4. clear evict会清除session缓存
5. save巨大数据,每20个数据,一般flush运行sql将数据持久化然后clear缓存。防止内存溢出。save放最后。
6. iterate使用一级缓存(creatQuery中的查询实体对象list会使用一级缓存,查询对象实体属性不会使用)
二级缓存
进程级别的缓存或sessionFactory缓存,能够被session共享,伴随sessionFactory存在和消亡。
查询缓存
仅仅缓存普通属性结果集的缓存,实体对象仅仅缓存id
生命周期:当查询关联的表发生改动,就结束。跟二级缓存无关。须要显示启用,query.setCacheable(true)而且仅仅对list起作用,对iterator不起作用。它不使用查询缓存。
抓取策略
1. 查询抓取fetch=join. 把外键关联的对象也取出来,一条SQL,会使lazy失效,提高效率,能够配置或原生SQL
2. Subselect 子查询策略
相关文章推荐
- php绘制图片验证码
- java-SpringMVC SMS短信发送详解
- NGINX源代码剖析 之 CPU绑定(CPU亲和性)
- PhpExcel中文帮助手册|PhpExcel使用方法
- [poj 1925] Spiderman 简单dp
- HUST 1017 Exact cover(DLX精确覆盖)
- PHP自动加载实用技巧
- bzoj 3600: 没有人的算术 替罪羊树
- PHPExcel导出excel 复制代码
- SDOI2016r1游记
- 【笔试/面试】—— Linux(文件内容查询)
- HARK学习(三)--文件格式
- 在个人电脑上搭建Ruby+Watir自动化测试环境
- ViewPager(一)——最简单的 ViewPage+Fragment实例
- Android ViewPager的学习
- Azure Service Fabric 开发环境搭建
- 500 G JAVA视频网盘分享(Jeecg社区)
- springmvc 处理模型数据
- BZOJ 1032 JSOI 2007 祖码Zuma 区间DP
- LeetCode 43. Multiply Strings