hibernate笔记--缓存机制之 二级缓存(sessionFactory)和查询缓存
二级缓存(sessionFactory):
Hibernate的二级缓存由SessionFactory对象管理,是应用级别的缓存。它可以缓存整个应用的持久化对象,所以又称为“SessionFactory缓存”.
hibernate二级缓存中的缓存对象可以被整个应用的Session对象共享,即使关闭当前Session对象,新建的Session对象仍可使用。使用Hibernate的二级缓存之后查询数据,Session对象会首先在以及缓存中查找有无缓存数据被命中。如果没有,则查找二级缓存。如果有,则直接返回所命中的数据;否则查询数据库
下面介绍在hibernate中如何开启和使用二级缓存:
1.在hibernate.cfg.xml中开启二级缓存,并且配置cache.region.factory_class:
<!-- 开启二级缓存 --><property name="cache.use_second_level_cache">false</property><!-- 配置cache.region.factory_classs --><property name="cache.region.factory_class">org.hibernate.cache.ehcache.EhCacheRegionFactory</property>
2:导入第三方jar包,(下载hibernate资源包,会在\lib\optional\ehcache文件夹下找到相关jar包):
3.在src目录下,新建ehcache.xml.或在hibernate资源包的\project\etc目录下找到该文件,copy到src目录下:
ehcache.xml:
<ehcache><diskStore path="java.io.tmpdir"/><!-- maxElementsInMemory:设置存放对象数量的最大值eternal:设置是否永久存储timeToIdleSeconds:设置对象的空闲时间timeToLiveSeconds:设置对象的存活时间overflowToDisk:内存溢出是否写入磁盘--><defaultCachemaxElementsInMemory="10000"eternal="false"timeToIdleSeconds="120"timeToLiveSeconds="120"overflowToDisk="true"/><cache name="sampleCache1"maxElementsInMemory="10000"eternal="false"timeToIdleSeconds="300"timeToLiveSeconds="600"overflowToDisk="true"/><cache name="sampleCache2"maxElementsInMemory="1000"eternal="true"timeToIdleSeconds="0"timeToLiveSeconds="0"overflowToDisk="false"/></ehcache>
4:在需要使用二级缓存的实体类的hbm.xml文件中设置,或在hibernate.cfg.xml中指定需要使用二级缓存的实体类:
以上一节的Book和Category为例,如果我需要开启Book的二级缓存:
*在Book.hbm.xml文件中的class标签下,添加一个标签:
<cache usage="read-only"/>
*或在hibernate.cfg.xml的mapping属性下面,添加:
<class-cache usage="read-only" class="com.wang.pojo.Book"/>
关于usage的取值,有以下几种:
只读缓存(read-only):如果应用程序需要读取一个持久化类的实例,但是并不打算修改它们,可以使用read-only缓存。这是最简单,也是实用性最好的策略.
读/写缓存(read-write): 如果应用程序需要更新数据,可能read-write缓存比较合适。如果需要序列化事务隔离级别,那么就不能使用这种缓存策略。
不严格的读/写缓存(nonstrict-read-write):如果程序偶尔需要更新数据(也就是说,出现两个事务同时更新同一个条目的现象很不常见),也不需要十分严格的事务隔离,可能适用nonstrict-read-write缓存。
事务缓存(transactional): transactional缓存策略提供了对全事务的缓存,仅仅在受管理环境中使用。它提供了Repeatable Read事务隔离级别。对于经常被读但很少修改的数据,可以采用这种隔离类型,因为它可以防止脏读和不可重复读这类的并发问题。
以上配置工作全部完成,我们来用代码,感受一下二级缓存的存在:
Session session=HibernateUtil.getSession();Book book =(Book) session.get(Book.class,1);System.out.println(book.getName());session.beginTransaction().commit();session.close();System.out.println(book.getName());
在这段代码中,我先查询了一下id=1的Book信息,然后关闭了session对象,很明显一级缓存肯定是不存在了,然后我再次打印book的name,我们先看看控制台的打印信息:
神奇的是发生了,居然没有报错,而且打印出了book的name,这就是二级缓存的作用.现在我们再来看看开头的第二段内容,就一目了然了.
hibernate二级缓存中的缓存对象可以被整个应用的Session对象共享,即使关闭当前Session对象,新建的Session对象仍可使用。使用Hibernate的二级缓存之后查询数据,Session对象会首先在以及缓存中查找有无缓存数据被命中。如果没有,则查找二级缓存。如果有,则直接返回所命中的数据;否则查询数据库
查询缓存:
查询缓存缓存的是查询出来的实体的部分属性结果集和实体的ID(注意这里不是实体).关于查询缓存和二级缓存的同时和分开使用的情况,网络上这一段解释的比较好,这里直接引用了:
当只是用Hibernate查询缓存而关闭二级缓存的时候:
第一:如果查询的是部分属性结果集: 那么当第二次查询的时候就不会发出SQL,直接从Hibernate查询缓存中取数据;
第二:如果查询的是实体结果集eg(from Student) ,首先Hibernate查询缓存存放实体的ID,第二次查询的时候就到Hibernate查询缓存中取出ID 一条一条的到数据库查询,这样,将发出N 条SQL造成了SQL泛滥。当都开启Hibernate查询缓存和二级缓存的时候:
第一:如果查询的是部分属性结果集: 这个和上面只是用Hibernate查询缓存而关闭 二级缓存的时候一致,因为不涉及实体不会用到二级缓存;
第二:如果查询的是实体结果集eg(from Student),首先Hibernate查询缓存存放实体的ID,第二次查询的时候,就到Hibernate查询缓存中取出ID,到二级缓存区找数据,如果有数据,就不会发出SQL;如果都有,一条SQL都不会发出,直接从二级缓存中取数据。
下面介绍如何开启和使用查询缓存:
1.在hibernate.cfg.xml中.添加一个标签语句:
<!-- 开启查询缓存 --><property name="cache.use_query_cache">true</property>
2.在代码中添加query.setCachemodel(true);
List<Book> list =(List) session.createQuery("from Book").setCacheable(true)//使用查询缓存 .list();System.out.println(list.get(0).getName());session.beginTransaction().commit();session.close();System.out.println(list.get(0).getName());
这里使用了list(),查询所有Book信息,关闭session以后再次打印list中的内容,依然能打印出来,不会报错,这就是查询缓存的使用.
注意:
查询缓存的生命周期与Session无关(可以跨Session查询),当查询关联的表发生改变,那么查询缓存的生命周期结束(delete、update、modify)
查询缓存是专为Query的list方法设计的。对于iterate()方法,无论是查询对象属性还是对象本身,查询缓存用与不用都没有区别!
转载于:https://www.cnblogs.com/fingerboy/p/5258930.html
hibernate笔记--缓存机制之 二级缓存(sessionFactory)和查询缓存相关推荐
- Mybatis(五) 延迟加载和缓存机制(一级二级缓存)
踏踏实实踏踏实实,开开心心,开心是一天不开心也是一天,路漫漫其修远兮. --WZY 一.延迟加载 延迟加载就是懒加载,先去查询主表信息,如果用到从表的数据的话,再去查询从表的信息,也就是如果没用到从表 ...
- 【Web缓存机制系列】2 – Web浏览器的缓存机制
Web缓存的工作原理 所有的缓存都是基于一套规则来帮助他们决定什么时候使用缓存中的副本提供服务(假设有副本可用的情况下,未被销毁回收或者未被删除修改).这些规则有的在协议中有定义(如HTTP协议1.0 ...
- mysql配置优化查询缓存_MySQL优化(4):查询缓存
查询缓存: MySQL提供的数据缓存QueryCache,用于缓存SELECT查询的结果 默认不开启,需要在配置文件中开启缓存(my.ini/my.cnf) 在[mysqld]段中,修改query_c ...
- 缓存机制(二级缓存)
二级缓存也称为sqlsessionFactory级缓存,通过同一个factory获取的sqlsession可以共享二级缓存,在应用服务器中sqlsessionfactory是单例的,因此二级缓存可以实 ...
- Hibernate学习——(十二)Hibernate缓存机制(一级、二级、查询)
一.why(为什么要用Hibernate缓存?) Hibernate是一个持久层框架,经常访问物理数据库. 为了降低应用程序对物理数据源访问的频次,从而提高应用程序的运行性能. 缓存内的数据是对物理数 ...
- Hibernate 缓存机制
转载:http://www.cnblogs.com/wean/archive/2012/05/16/2502724.html 一.why(为什么要用Hibernate缓存?) Hibernate是一个 ...
- hibernate缓存机制详细介绍
hibernate的缓存机制,包括一级缓存(session级别).二级缓存(sessionFactory级别). 一:hibernate的 N+1问题 list()获得对象: 如果通过list()方法 ...
- Hibernate 一级缓存,二级缓存,查询缓存
概念: 1.什么是缓存呢? 缓存:是计算机领域的概念,它介于应用程序和永久性数据存储源之间. 缓存:一般人的理解是在内存中的一块空间,可以将二级缓存配置到硬盘.用白话来说,就是一个存储数据的容器.我们 ...
- (11) Hibernate 缓存机制
一.why(为什么要用Hibernate缓存?) Hibernate是一个持久层框架,经常访问物理数据库. 为了降低应用程序对物理数据源访问的频次,从而提高应用程序的运行性能. 缓存内的数据是对物理数 ...
- hibernate缓存机制与N+1问题
在项目中遇到的趣事 本文基于hibernate缓存机制与N+1问题展开思考, 先介绍何为N+1问题 再hibernate中用list()获得对象: 1 /** 2 * 此时会发出一条sql,将30个学 ...
最新文章
- centos 打包某个目录_Linux目录基础,带你了解Linux神秘面纱
- 大数据-07-Spark之流数据
- linux 虚函数调用性能,C++虚函数和多态
- 智能车竞赛技术报告 | 节能信标组 - 洛阳理工学院 - Since 2021
- linux 系统基础知识 - fdisk命令
- DevOps文档中心的技术实践演进
- Luogu P2319 [HNOI2006]超级英雄
- Javascript图片滚动
- 爬虫新宠requests_html 带你甄别2019虚假大学 #华为云·寻找黑马程序员#
- ios java环境变量_iOS 环境变量配置(DebugReleaseTest)
- SharePoint列表下拉框优化
- 在sealos搭建的k8s集群中自定义kubeconfig文件
- tf卡可以自己裁剪成nm卡_[Vivado 2020.1]ZYNQ7020折腾之路(四)之荔枝糖Hex固化程序到TF卡...
- java 对错代厔_汉字转拼音源码的两个类
- [Recap] Huobi GitChat Meetup
- Chrome保存整个网页为图片、PDF
- 计算机什么是符号健,在电脑健盘上怎么打:符号
- 浅谈对象的深拷贝和浅拷贝
- oracle导入指定字符集入,EXP/IMP 与 字符集、导入导出等
- 5分钟弄懂语音识别技术原理