hibernate优化(二):缓存
2016-04-06 22:23
288 查看
1.缓存的概念
hibernate缓存包括Session缓存和SessionFactory缓存,其中SessionFactory缓存又可以分为两类:内置缓存和外置缓存。Session缓存是内置的,不能被卸载,也被称为hibernate的第一级缓存。SessionFactory外置缓存也被称为hibernate的第二级缓存。二级缓存是可选择的。
1.1缓存范围
事务缓存:缓存只能被当前事务访问,线程安全
进程缓存:缓存被进程内的所有事务共享,可能并发
集群缓存:缓存被一或多个计算机访问,可能并发
1.2缓存并发访问策略
事务性:可以避免脏读和不可重复读
读写型:可以避免脏读
非严格读写型:允许偶尔的脏读
只读型:对于从来都不会修改的数据
2.一级缓存
hibernate在查询时首先查询一级缓存,若没有则再进行下一步(数据库或二级缓存)
session的相关方法
session.list()和session.iterator()的却别:
1).list()直接取出所有,iterator()先取ID,然后用到某个对象时,根据ID发sql取出 (当只需要某个对象的时候用iterator使用)
2).list()第二次查询,还会直接从数据库中查询,iterator()会使用session缓存,如果缓存中没用再发sql
3.二级缓存
二级缓存包含这些内容:查询缓存、并发访问策略、缓存适配器
3.1二级缓存的常用插件:
EHCache、OSCache、SwarmCache
3.2打开二级缓存
i. hibernate.cfg.xml 设定:
<property
name="cache.use_second_level_cache">true</property>
<property
name="cache.provider_class">org.hibernate.cache.EhCacheProvider</property>
ii. @Cache注解(由hibernate扩展提供)
@Cache(usage=CacheConcurrencyStrategy.READ_WRITE)
注:使用EhCache二级缓存
需要导入ehcache-1.2.3.jar及commons-logging-1.0.4.jar包
load默认使用二级缓存,iterate默认使用二级缓存
f) list默认往二级缓存加数据,但是查询的时候不使用
g) 如果要query用二级缓存,需打开查询缓存
<propertyname="cache.use_query_cache">true</property>
调用Query的setCachable(true)方法指明使用二级缓存
例如:session.createQuery("fromCategory").setCacheable(true).list();
hibernate缓存包括Session缓存和SessionFactory缓存,其中SessionFactory缓存又可以分为两类:内置缓存和外置缓存。Session缓存是内置的,不能被卸载,也被称为hibernate的第一级缓存。SessionFactory外置缓存也被称为hibernate的第二级缓存。二级缓存是可选择的。
1.1缓存范围
事务缓存:缓存只能被当前事务访问,线程安全
进程缓存:缓存被进程内的所有事务共享,可能并发
集群缓存:缓存被一或多个计算机访问,可能并发
1.2缓存并发访问策略
事务性:可以避免脏读和不可重复读
读写型:可以避免脏读
非严格读写型:允许偶尔的脏读
只读型:对于从来都不会修改的数据
2.一级缓存
hibernate在查询时首先查询一级缓存,若没有则再进行下一步(数据库或二级缓存)
session的相关方法
session.evit(Object obj); //从缓存中清除指定对象 session.clear(); //清空缓存,不同步数据库 session.flush(); //强制从内存到数据库同步
session.list()和session.iterator()的却别:
1).list()直接取出所有,iterator()先取ID,然后用到某个对象时,根据ID发sql取出 (当只需要某个对象的时候用iterator使用)
2).list()第二次查询,还会直接从数据库中查询,iterator()会使用session缓存,如果缓存中没用再发sql
3.二级缓存
二级缓存包含这些内容:查询缓存、并发访问策略、缓存适配器
3.1二级缓存的常用插件:
EHCache、OSCache、SwarmCache
3.2打开二级缓存
i. hibernate.cfg.xml 设定:
<property
name="cache.use_second_level_cache">true</property>
<property
name="cache.provider_class">org.hibernate.cache.EhCacheProvider</property>
ii. @Cache注解(由hibernate扩展提供)
@Cache(usage=CacheConcurrencyStrategy.READ_WRITE)
注:使用EhCache二级缓存
需要导入ehcache-1.2.3.jar及commons-logging-1.0.4.jar包
load默认使用二级缓存,iterate默认使用二级缓存
f) list默认往二级缓存加数据,但是查询的时候不使用
g) 如果要query用二级缓存,需打开查询缓存
<propertyname="cache.use_query_cache">true</property>
调用Query的setCachable(true)方法指明使用二级缓存
例如:session.createQuery("fromCategory").setCacheable(true).list();
相关文章推荐
- MySQL 优化
- Google排名优化的几个影响因素
- DB2优化(简易版)
- Mysql limit 优化,百万至千万级快速分页 复合索引的引用并应用于轻量级框架
- C#中尾递归的使用、优化及编译器优化
- 对优化Ruby on Rails性能的一些办法的探究
- 优化Ruby脚本效率实例分享
- Asp编码优化技巧
- 如何监测和优化OLAP数据库
- 浅析SQL Server中的执行计划缓存(上)
- mysql -参数thread_cache_size优化方法 小结
- 深入学习SQL Server聚合函数算法优化技巧
- Enterprise Library for .NET Framework 2.0缓存使用实例
- PowerShell中编程清空IE缓存方法
- PowerShell中使用.NET将程序集加入全局程序集缓存
- C#中缓存的基本用法总结
- MySQL常见的底层优化操作教程及相关建议
- 详解mysql的limit经典用法及优化实例
- 数据库学习建议之提高数据库速度的十条建议
- oracle数据库sql的优化总结