本帖最后由 鱼丸儿 于 2018-1-20 11:44 编辑

大家好,今天来记录讲解一下磕磕绊绊的hibernate5 的二级缓存配置,一条路摸到黑 
那么在这之前我们先了解一下hibernate的一级缓存和二级缓存分别是什么? 
说句通俗的话就是 一级缓存的信息只能在同一个session间传递,而二级缓存是不同的session间可以访问的,可以跨越Session存在,可以被多个Session所共享。需要第三方缓存框架的加持

那么什么数据适合放到二级缓存中呢? 
便是那些不经常改动又经常被访问的数据,比如省市信息等,前台页面经常查询而没必要每次都要去数据库查询!

那么有什么三方框架可以支持hibernate的二级缓存呢? 
EHCache: 可作为进程范围内的缓存,存放数据的物理介质可以是内存或硬盘,对Hibernate的查询缓存提供了支持 
OpenSymphony:可作为进程范围内的缓存,存放数据的物理介质可以是内存或硬盘,提供了丰富的缓存数据过期策略,对Hibernate的查询缓存提供了支持 
SwarmCache:可作为集群范围内的缓存,但不支持Hibernate的查询缓存 
JBossCache:可作为集群范围内的缓存,支持Hibernate的查询缓存

好,那么我们接下来就以EHCache来介绍一下hibernate二级缓存的用法

第一步:导入jar包(jar包附件给出)

[Java] 纯文本查看 复制代码
1
2
3
ehcache-core-2.4.3.jar 
hibernate-ehcache-5.0.7.Final.jar 
commons-logging-1.1.1.jar

第二步:声明缓存(在hibernate.cfg.xml 中配置)

[XML] 纯文本查看 复制代码
1
2
3
4
5
6
7
<!-- 使用二级缓存 --> 
<property name="hibernate.cache.use_second_level_cache">true</property
<!--设置缓存的类型,设置缓存的提供商 --> 
<property name="hibernate.cache.region.factory_class">org.hibernate.cache.ehcache.SingletonEhCacheRegionFactory</property
<!--但是在 hibernate 4中设置缓存提供商时是这样设置的 
<property name="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</property>--> 
<property name="hibernate.cache.use_query_cache">true</property>

第三步:需要设置EHCache配置文件

[XML] 纯文本查看 复制代码
01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="../config/ehcache.xsd" 
   
 <diskStore path="C:/ehcache"/><!-- 需要在你的磁盘里面添加该目录 --> 
         <defaultCache     
            maxElementsInMemory="10000"  
            eternal="false"   
            timeToIdleSeconds="120"  
            timeToLiveSeconds="120"  
            overflowToDisk="true"  
            maxElementsOnDisk="10000000"  
            diskExpiryThreadIntervalSeconds="120"   
            memoryStoreEvictionPolicy="LRU"    
            />   
</ehcache>

第四步:指定什么对象也就是model可以加入缓存 
有两种配置方式,可以在hbm中创建安,也可以在cfg文件中创建 
我们这里就以cfg文件配置为例

[XML] 纯文本查看 复制代码
1
2
3
4
<class-cache usage="read-write" class="cn.patronli.domain.Order"/> <!-缓存的是对象- 
<collection-cache usage="read-write" collection="cn.patronli.domain.Customer.orders"/> <!-缓存的是集合- 
   
为了保险起见 我们需要给相对应的model  实现一个序列化接口 implements Serializable

那么如何在hbm中设置呢?需要再class后紧跟缓存配置,如下所示

[XML] 纯文本查看 复制代码
1
2
<class name="Customer" table="t_customer" catalog="hibernateTest" lazy="true"
    <cache usage="read-write"/>

以上配置二选一 !!!!

那么最后我们就可以来进行测试了

[Java] 纯文本查看 复制代码
01
02
03
04
05
06
07
08
09
10
11
12
13
14
public static void main(String[] args) {   
             
        Session s1 = HibernateUtils.openSession(); 
        s1.beginTransaction();   
        Customer c1 = (Customer) s1.get(Customer.class, 1); // 从数据库中加载数据   
        System.out.println(c1.getName()); 
        s1.getTransaction().commit();   
        s1.close(); // 关闭session级别的一级缓存   
     
        Session s2 = HibernateUtils.openSession(); 
        s2.beginTransaction();   
        Customer c2 = (Customer) s2.get(Customer.class, 1); // 因为有了二级缓存的存在,并不会去查询数据库可以debug  观察控制台打印 
        System.out.println(c2.getName());   
    }

不知道你学会了没有?

hibernate 5的二级缓存案例讲解的更多相关文章

  1. Hibernate的一级二级缓存机制配置与测试

    特别感谢http://www.cnblogs.com/xiaoluo501395377/p/3377604.html 在本篇随笔里将会分析一下hibernate的缓存机制,包括一级缓存(session ...

  2. hibernate 查询、二级缓存、连接池

    hibernate 查询.二级缓存.连接池 查询: 1) 主键查询 Dept dept =  (Dept) session.get(Dept.class, 12); Dept dept =  (Dep ...

  3. Hibernate中 一 二级缓存及查询缓存(1)

    最近趁有空学习了一下Hibernate的缓存,其包括一级缓存,二级缓存和查询缓存(有些是参照网络资源的): 一.一级缓存     一级缓存的生命周期和session的生命周期一致,当前sessioin ...

  4. Hibernate-ORM:16.Hibernate中的二级缓存Ehcache的配置

    ------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- 本篇博客讲述Hibernate中的二级缓存的配置,作者将使用的是ehcache缓存 一,目录 1.二级缓存的具 ...

  5. 具体解释Hibernate中的二级缓存

    1.前言 这篇博客再前几篇博客的基础上来解说一下.Hibernate中的二级缓存.二级缓存是属于SessionFactory级别的缓存机制. 第一级别的缓存是Session级别的缓存,是属于事务范围的 ...

  6. Hibernate+EhCache配置二级缓存

    步骤: 第一步:加入ehcache.jar 第二步: 在src目录下新建一个文件,名为:ehcache.xml 第三步:在hibernate配置文件的<session-factory>下配 ...

  7. Spring 整合 Hibernate 时启用二级缓存实例详解

    写在前面: 1. 本例使用 Hibernate3 + Spring3: 2. 本例的查询使用了 HibernateTemplate: 1. 导入 ehcache-x.x.x.jar 包: 2. 在 a ...

  8. Hibernate笔记④--一级二级缓存、N+1问题、saveorupdate、实例代码

    一级缓存及二级缓存 一级缓存也是Session 缓存     一个链接用户的多次查询使用缓存     跨用户 则无缓存     hibernate自带的 get和load都会填充并利用一级缓存 二级缓 ...

  9. Hibernate中 一 二级缓存及查询缓存(2)

    缓存:缓存是什么,解决什么问题?  位于速度相差较大的两种硬件/软件之间的,用于协调两者数据传输速度差异的结构,均可称之为缓存Cache.缓存目的:让数据更接近于应用程序,协调速度不匹配,使访问速度更 ...

随机推荐

  1. hdu1421_搬寝室

    题目:搬寝室 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1421 #include<stdio.h> #include<algor ...

  2. day 7-17 多表查询

    一. 准备表 #部门表 create table dep( id int, name varchar(20) ); #员工表 create table emp( id int primary key ...

  3. 金蝶CLOUD与EAS的区别

    1.金蝶K/3 WISE主要面向单体制造企业(主要是离散制造企业):2.金蝶K/3 Cloud主要面向业务类型单一(即主营业务单一)的.注重供应链与生产业务协同的.中小型(二层集团??)集团性企业(主 ...

  4. word的"bug"

    发表博客发现,从word复制文本到chrome浏览器上的博客时, 如果复制完后立即关闭word,那么将无法粘贴到通过chrome浏览器访问的博客上,也无法粘贴到记事本上: 但是复制完立即关闭word后 ...

  5. AJAX+springmvc遇到的问题

    当我使用AJAX将表单的值传入处理器中后,经过了一个判断再进行页面跳转时,不能在处理器中使用重定向,它会将重定向的页面内容在AJAX的data中显示出来而不是显示一个页面 所以只能在AJAX 的suc ...

  6. linux 下crontab -e 命令插入及保存

    由于功能需要,用到linux定时任务. 一般我们都是crontab -e 进去写好定时任务,直接保存退出就可以了,如果是第一次创建定时任务, 系统会选择默认编辑器,就不好保存文件. 在网上参考了一篇文 ...

  7. MBG逆向工程报错:generate failed: Exception getting JDBC Driver: com.mysql.jdbc.Driver

    修改pom文件,逆向工程如下: <!-- 逆向工程 --> <plugin> <groupId>org.mybatis.generator</groupId& ...

  8. spring 给一个类 生成test

    右击一个类,然后:GoTo==>test ,就可以新建这个类的测试用例了,简单粗暴, 如果想要不污染数据库,就在一个测试用例 的标签@Test 下面在加上@RollBack 这样: @Test ...

  9. 集合之LinkedHashSet(含JDK1.8源码分析)

    一.前言 上篇已经分析了Set接口下HashSet,我们发现其操作都是基于hashMap的,接下来看LinkedHashSet,其底层实现都是基于linkedHashMap的. 二.linkedHas ...

  10. python数据结构与算法第五天【顺序表】

    1.列表存储的两种方式 (1)元素内置方式 采用元素内置的方式只能存放同类型元素的数据类型,例如列表中的元素都为整形,元素类型相同,每个元素存放的地址空间大小也相同,则列表中每个元素都是顺序存放的 ( ...