一级缓存就是Session级别的缓存,close后就没了。

二级缓存就是SessionFactory级别的缓存,全局缓存,要配置其他插件。

 什么样的数据适合存放到第二级缓存中?

  1、很少被修改的数据

  2、不是很重要的数据,允许出现偶尔并发的数据

  3、不会被并发访问的数据

  4、参考数据

  不适合存放到第二级缓存的数据?

  1、经常被修改的数据

  2、财务数据,绝对不允许出现并发

  3、与其他应用共享的数据。

        Hibernate的二级缓存策略的一般过程如下:

  1) 条件查询的时候,总是发出一条select * from table_name where …. (选择所有字段)这样的SQL语句查询数据库,一次获得所有的数据对象。

  2) 把获得的所有数据对象根据ID放入到第二级缓存中。

  3) 当Hibernate根据ID访问数据对象的时候,首先从Session一级缓存中查;查不到,如果配置了二级缓存,那么从二级缓存中查;查不到,再查询数据库,把结果按照ID放入到缓存。

  4) 删除、更新、增加数据的时候,同时更新缓存。

      配置2级缓存

   Hibernate有很多值得学习的地方,这里我们主要介绍配置Hibernate二级缓存,包括介绍在Spring托管的Hibernate二级缓存等方面。

使用EhCache配置Hibernate二级缓存:

配置Hibernatee二级缓存准备:

1)把ehcache-1.2.3.jar加入到当前应用的classpath中。

2)在hibernate.cfg.xml文件中加入EhCache缓存插件的提供类。

  1. <property name="hibernate.cache.provider_class">
  2. org.hibernate.cache.EhCacheProvider
  3. </property>

3)挎贝ehcache.xml文件到类路径(项目工程的src目录下),这个文件在Hibernate安装目录的etc下。

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
  3. "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
  4. <hibernate-mapping>
  5. <class name="org.qiujy.domain.cachedemo.Category" table="categories">
  6. //配置缓存,必须紧跟在class元素后面对缓存中的Category对象采用读写型的并发访问策略
  7. <cache usage="read-write"/>
  8. <id name="id" type="java.lang.Long">
  9. <column name="id" />
  10. <generator class="native" />
  11. </id>
  12. <!-- 配置版本号,必须紧跟在id元素后面 -->
  13. <version name="version" column="version" type="java.lang.Long" />
  14. <property name="name" type="java.lang.String">
  15. <column name="name" length="32" not-null="true"/>
  16. </property>
  17. <property name="description" type="java.lang.String">
  18. <column name="description" length="255"/>
  19. </property>
  20. <set name="products" table="products" cascade="all" inverse="true">
  21. <cache usage="read-write"/>
  22. <key column="categoryId" not-null="true"/>
  23. <one-to-many class="org.qiujy.domain.cachedemo.Product"/>
  24. </set>
  25. </class>
  26. </hibernate-mapping>

Product.hbm.xml

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
  3. "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
  4. <hibernate-mapping>
  5. <class name="org.qiujy.domain.cachedemo.Product" table="products">
  6. <cache usage="read-write"/>
  7. <id name="id" type="java.lang.Long">
  8. <column name="id" />
  9. <generator class="native" />
  10. </id>
  11. <!-- 配置版本号,必须紧跟在id元素后面 -->
  12. <version name="version" column="version" type="java.lang.Long" />
  13. <property name="name" type="java.lang.String">
  14. <column name="name" length="32" not-null="true"/>
  15. </property>
  16. <property name="description" type="java.lang.String">
  17. <column name="description" length="255"/>
  18. </property>
  19. <property name="unitCost" type="java.lang.Double">
  20. <column name="unitCost" />
  21. </property>
  22. <property name="pubTime" type="java.util.Date">
  23. <column name="pubTime" not-null="true" />
  24. </property>
  25. <many-to-one name="category"
  26. column="categoryId"
  27. class="org.qiujy.domain.cachedemo.Category"
  28. cascade="save-update"
  29. not-null="true">
  30. </many-to-one>
  31. </class>
  32. </hibernate-mapping>

编辑ehcache.xml文件:

  1. <ehcache>
  2. <diskStore path="c:\\ehcache\"/>
  3. <defaultCache
  4. maxElementsInMemory="10000"
  5. eternal="false"
  6. timeToIdleSeconds="120"
  7. timeToLiveSeconds="120"
  8. overflowToDisk="true"
  9. />
  10. <!-- 设置Category类的缓存的数据过期策略 -->
  11. <cache name="org.qiujy.domain.cachedemo.Category"
  12. maxElementsInMemory="100"
  13. eternal="true"
  14. timeToIdleSeconds="0"
  15. timeToLiveSeconds="0"
  16. overflowToDisk="false"
  17. />
  18. <!-- 设置Category类的products集合的缓存的数据过期策略 -->
  19. <cache name="org.qiujy.domain.cachedemo.Category.products"
  20. maxElementsInMemory="500"
  21. eternal="false"
  22. timeToIdleSeconds="300"
  23. timeToLiveSeconds="600"
  24. overflowToDisk="true"
  25. />
  26. <cache name="org.qiujy.domain.cachedemo.Product"
  27. maxElementsInMemory="500"
  28. eternal="false"
  29. timeToIdleSeconds="300"
  30. timeToLiveSeconds="600"
  31. overflowToDisk="true"
  32. />
  33. </ehcache>

在Spring托管的Hibernate二级缓存
1.在spring的配置文件中,hibernate部分加入 xml 代码 org.hibernate.cache.EhCacheProvider true
2.为HBM表设置cache策略 xml 代码
3.在DAO中,调用find方法查询之前,设置使用缓存 Java代码 getHibernateTemplate().setCacheQueries(true);

补充:
如果不设置“查询缓存”,那么Hibernate只会缓存使用load()方法获得的单个持久化对象,如果想缓存使用findall()、list()、
Iterator()、createCriteria()、createQuery()等方法获得的数据结果集的话,就需要设置
hibernate.cache.use_query_cache true 才行。

hibernate的一级和二级缓存的更多相关文章

  1. Hibernate的查询,二级缓存,连接池

    Hibernate的查询,二级缓存,连接池 1.Hibernate查询数据 Hibernate中的查询方法有5中: 1.1.Get/Load主键查询 使用get或者load方法来查询,两者之间的区别在 ...

  2. hibernate框架学习之二级缓存

    缓存的意义 l应用程序中使用的数据均保存在永久性存储介质之上,当应用程序需要使用数据时,从永久介质上进行获取.缓存是介于应用程序与永久性存储介质之间的一块数据存储区域.利用缓存,应用程序可以将使用的数 ...

  3. Mybatis一级、二级缓存

      Mybatis一级.二级缓存   一级缓存 首先做一个测试,创建一个mapper配置文件和mapper接口,我这里用了最简单的查询来演示. <mapper namespace="c ...

  4. hibernate框架学习之二级缓存(测试用例)

    HqlDemoApp.java package cn.itcast.h3.query.hql; import java.io.Serializable; import org.hibernate.Qu ...

  5. Hibernate 性能优化之二级缓存

    二级缓存是一个共享缓存,在二级缓存中存放的数据是共享数据特性     修改不能特别频繁     数据可以公开二级缓存在sessionFactory中,因为sessionFactory本身是线程安全,所 ...

  6. MyBatis 一级、二级缓存

    一级 默认session就有一级缓存,session有C/U/D操作或者session.clearCache();session.commit();都会清空缓存: 二级在mapper.xml中添加&l ...

  7. mybatis学习--缓存(一级和二级缓存)

    声明:学习摘要! MyBatis缓存 我们知道,频繁的数据库操作是非常耗费性能的(主要是因为对于DB而言,数据是持久化在磁盘中的,因此查询操作需要通过IO,IO操作速度相比内存操作速度慢了好几个量级) ...

  8. 【mybatis源码学习】mybtias一级,二级缓存

    转载:https://www.cnblogs.com/ysocean/p/7342498.html mybatis 为我们提供了一级缓存和二级缓存,可以通过下图来理解: ①.一级缓存是SqlSessi ...

  9. Hibernate 集成 Ehcache 开启二级缓存

    一.将 Ehcache.xml 放到 classpath 下 <?xml version="1.0" encoding="UTF-8"?> < ...

随机推荐

  1. Ubutu Chrome 出现adobe flash is out of date的解决方法

    我们需要到官网下载flash player,网址:https://get.adobe.com/flashplayer/ 不过这里要说明一下: 一般的浏览器使用的是npapi,即adobe flash ...

  2. windows下使用docker安装tensorflow

    一.安装Docker 1.首先先按照docker,从https://get.daocloud.io/toolbox/  下载exe文件就好 双击安装会多出来三个东西: Oracle VM Virtua ...

  3. ucos-ii的任务调度机制

    1.在ucos-ii中,有这么几张表来管理任务. A.OSTCBPrioTbl[],其结构为OS_TCB指针的数组,其元素个数为64, 每一个元素对应一个任务的优先级,ucos-ii最多可以有64个任 ...

  4. Linux显示登入系统的帐号名称和总人数

    Linux显示登入系统的帐号名称和总人数 youhaidong@youhaidong-ThinkPad-Edge-E545:~$ who -q youhaidong youhaidong # 用户数= ...

  5. TCP粘包、拆包及解决

    TCP属于传输层的协议,传输层除了有TCP协议外还有UDP协议.那么UDP是否会发生粘包或拆包的现象呢?答案是不会.UDP是基于报文发送的,从UDP的帧结构可以看出,在UDP首部采用了16bit来指示 ...

  6. Vasya and Basketball CodeForces - 493C

    Vasya follows a basketball game and marks the distances from which each team makes a throw. He knows ...

  7. zookeeper选举

    什么时候开始进行选举 1.服务器初始化启动的时候2.服务器运行期间连接不上leader的时候 初始化选举过程 进行leader选举至少需要两台服务器,我们这里举例为5台服务器(1,2,3,4,5)1. ...

  8. JavaScript设计模式(3)-工厂模式

    工厂模式 1. 简单工厂 简单工厂:使用一个类或对象封装实例化操作 假如我们有个自行车商店类 BicycleShop,它提供了销售自行车的方法可以选择销售两类自行车 Speedster,Comfort ...

  9. 主席树总结(经典区间第k小问题)(主席树,线段树)

    接着上一篇总结--可持久化线段树来整理吧.点击进入 这两种数据结构确实有异曲同工之妙.结构是很相似的,但维护的主要内容并不相同,主席树的离散化.前缀和等思想也要更难理解一些. 闲话 话说刚学习主席树的 ...

  10. [BZOJ1507] [NOI2003] Editor (splay)

    Description Input 输入文件editor.in的第一行是指令条数t,以下是需要执行的t个操作.其中: 为了使输入文件便于阅读,Insert操作的字符串中可能会插入一些回车符,请忽略掉它 ...