文章目录

  • 1、MyBatis的一级缓存
  • 2、MyBatis的二级缓存
    • 2.1、二级缓存开启的条件
    • 2.2、使二级缓存失效的情况
    • 2.3、`<cache>`相关配置
  • 3、MyBatis缓存查询顺序
  • 4、整合第三方缓存EHCache
    • 4.1、添加依赖
    • 4.2、各jar包功能
    • 4.3、创建EHCache的配置文件ehcache.xml
    • 4.4、设置二级缓存的类型
    • 4.5、加入logback日志
    • 4.6、EHCache配置文件说明

MyBatis 内置了一个强大的事务性查询 缓存 机制,它可以非常方便地配置和定制。

默认情况下,只启用了本地的会话缓存,它仅仅对一个会话中的数据进行缓存。 要启用全局的二级缓存,只需要在你的 SQL 映射文件中添加一行:<cache/>

1、MyBatis的一级缓存

一级缓存是SqlSession级别的,通过同一个SqlSession查询的数据会被缓存,下次查询相同的数据,就 会从缓存中直接获取,不会从数据库重新访问

使一级缓存失效的四种情况:

  1. 不同的SqlSession对应不同的一级缓存
  2. 同一个SqlSession但是查询条件不同
  3. 同一个SqlSession两次查询期间执行了任何一次增删改操作
  4. 同一个SqlSession两次查询期间手动sqlSession.clearCache()清空了缓存

2、MyBatis的二级缓存

二级缓存是SqlSessionFactory级别,通过同一个SqlSessionFactory创建的SqlSession查询的结果会被 缓存;此后若再次执行相同的查询语句,结果就会从缓存中获取

2.1、二级缓存开启的条件

  1. 在核心配置文件中,设置全局配置属性cacheEnabled=“true”,默认为true,不需要设置
  2. 在映射文件中设置标签<cache />,这个简单语句的效果如下:
    1. 映射语句文件中的所有 select 语句的结果将会被缓存
    2. 映射语句文件中的所有 insert、update 和 delete 语句会刷新缓存
    3. 缓存会使用最近最少使用算法(LRU, Least Recently Used)算法来清除不需要的缓存。
    4. 缓存不会定时进行刷新(也就是说,没有刷新间隔)
    5. 缓存会保存列表或对象(无论查询方法返回哪种)的 1024 个引用
    6. 缓存会被视为读/写缓存,这意味着获取到的对象并不是共享的,可以安全地被调用者修改,而不干扰其他调用者或线程所做的潜在修改
  3. 二级缓存必须在SqlSession关闭或提交之后有效
  4. 查询的数据所转换的实体类类型必须实现序列化的接口

2.2、使二级缓存失效的情况

两次查询之间执行了任意的增删改,会使一级和二级缓存同时失效

2.3、<cache>相关配置

  1. eviction属性:缓存回收策略

    1. LRU(Least Recently Used) –【默认值】 最近最少使用的:移除最长时间不被使用的对象
    2. FIFO(First in First out) – 先进先出:按对象进入缓存的顺序来移除它们
    3. SOFT – 软引用:移除基于垃圾回收器状态和软引用规则的对象
    4. WEAK – 弱引用:更积极地移除基于垃圾收集器状态和弱引用规则的对象
  2. flushInterval属性:刷新间隔,单位毫秒
    1. 默认情况是不设置,也就是没有刷新间隔,缓存仅仅调用增删改语句时刷新
  3. size属性:引用数目,正整数
    1. 代表缓存最多可以存储多少个对象,太大容易导致内存溢出
  4. readOnly属性:只读,true/false
    1. true:只读缓存;会给所有调用者返回缓存对象的相同实例。因此这些对象不能被修改。这提供了 很重要的性能优势
    2. false:【默认值】读写缓存;会返回缓存对象的拷贝(通过序列化)。这会慢一些,但是安全!
  5. type属性:指定第三方缓存当作MyBatis的二级缓存

栗子:

<!--这个更高级的配置创建了一个 FIFO 缓存每隔 60 秒刷新最多可以存储结果对象或列表的 512 个引用而且返回的对象被认为是只读的因此对它们进行修改可能会在不同线程中的调用者产生冲突
-->
<cacheeviction="FIFO"flushInterval="60000"size="512"readOnly="true"/>

3、MyBatis缓存查询顺序

  1. 先查询二级缓存,因为二级缓存中可能会有其他程序已经查出来的数据,可以拿来直接使用
  2. 如果二级缓存没有命中,再查询一级缓存
  3. 如果一级缓存也没有命中,则查询数据库
  4. SqlSession关闭之后,一级缓存中的数据会写入二级缓存

注意!!!以下内容仅做了解,小白并未实践,暂做记录,后续用到再更新实况


4、整合第三方缓存EHCache

4.1、添加依赖

<!-- Mybatis EHCache整合包 -->
<dependency><groupId>org.mybatis.caches</groupId><artifactId>mybatis-ehcache</artifactId><version>1.2.1</version>
</dependency>
<!-- slf4j日志门面的一个具体实现 -->
<dependency><groupId>ch.qos.logback</groupId><artifactId>logback-classic</artifactId><version>1.2.3</version>
</dependency>

4.2、各jar包功能

jar包名称 作用
mybatis-ehcache Mybatis和EHCache的整合包
ehcache EHCache核心包
slf4j-api SLF4J日志门面包
logback-classic 支持SLF4J门面接口的一个具体实现

4.3、创建EHCache的配置文件ehcache.xml

<?xml version="1.0" encoding="utf-8" ?>
<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:noNamespaceSchemaLocation="../config/ehcache.xsd"><!-- 磁盘保存路径 --><diskStore path="D:\atguigu\ehcache"/><defaultCachemaxElementsInMemory="1000"maxElementsOnDisk="10000000"eternal="false"overflowToDisk="true"timeToIdleSeconds="120"timeToLiveSeconds="120"diskExpiryThreadIntervalSeconds="120"memoryStoreEvictionPolicy="LRU"></defaultCache>
</ehcache>

4.4、设置二级缓存的类型

<cache type="org.mybatis.caches.ehcache.EhcacheCache"/>

4.5、加入logback日志

存在SLF4J时,作为简易日志的log4j将失效,此时我们需要借助SLF4J的具体实现logback来打印日志。 创建logback的配置文件logback.xml

<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="true"><!-- 指定日志输出的位置 --><appender name="STDOUT"class="ch.qos.logback.core.ConsoleAppender"><encoder><!-- 日志输出的格式 --><!-- 按照顺序分别是:时间、日志级别、线程名称、打印日志的类、日志主体内容、换行 --><pattern>[%d{HH:mm:ss.SSS}] [%-5level] [%thread] [%logger] [%msg]%n</pattern></encoder></appender><!-- 设置全局日志级别。日志级别按顺序分别是:DEBUG、INFO、WARN、ERROR --><!-- 指定任何一个日志级别都只打印当前级别和后面级别的日志。 --><root level="DEBUG"><!-- 指定打印日志的appender,这里通过“STDOUT”引用了前面配置的appender --><appender-ref ref="STDOUT" /></root><!-- 根据特殊需求指定局部日志级别 --><logger name="com.xxx.crowd.mapper" level="DEBUG"/>
</configuration>

4.6、EHCache配置文件说明

属性名 是否必须 作用
maxElementsInMemory 在内存中缓存的element的最大数目
maxElementsOnDisk 在磁盘上缓存的element的最大数目,若是0表示无 穷大
eternal 设定缓存的elements是否永远不过期。 如果为 true,则缓存的数据始终有效, 如果为false那么还 要根据timeToIdleSeconds、timeToLiveSeconds 判断
overflowToDisk 设定当内存缓存溢出的时候是否将过期的element 缓存到磁盘上
timeToIdleSeconds 当缓存在EhCache中的数据前后两次访问的时间超 过timeToIdleSeconds的属性取值时, 这些数据便 会删除,默认值是0,也就是可闲置时间无穷大
timeToLiveSeconds 缓存element的有效生命期,默认是0.,也就是 element存活时间无穷大
diskSpoolBufferSizeMB DiskStore(磁盘缓存)的缓存区大小。默认是 30MB。每个Cache都应该有自己的一个缓冲区
diskPersistent 在VM重启的时候是否启用磁盘保存EhCache中的数 据,默认是false
diskExpiryThreadIntervalSeconds 磁盘缓存的清理线程运行间隔,默认是120秒。每 个120s, 相应的线程会进行一次EhCache中数据的 清理工作
memoryStoreEvictionPolicy 当内存缓存达到最大,有新的element加入的时 候, 移除缓存中element的策略。 默认是LRU(最 近最少使用),可选的有LFU(最不常使用)和 FIFO(先进先出)

九、MyBatis的缓存相关推荐

  1. 十、MyBatis的缓存

    文章目录 十.MyBatis的缓存 10.1 MyBatis的一级缓存 场景1:判断同一个sqlSession是否查询1级缓存,答案:会查询1级缓存 场景2:判断不同sqlSession是否查询1级缓 ...

  2. 深入了解MyBatis二级缓存

    深入了解MyBatis二级缓存 一.创建Cache的完整过程 我们从SqlSessionFactoryBuilder解析mybatis-config.xml配置文件开始: Reader reader ...

  3. springboot mybatis 事务_SpringBoot 下 Mybatis 的缓存

    "IT魔幻屋"致力于让你遇见更好的自己! 说起 mybatis,作为 Java 程序员应该是无人不知,它是常用的数据库访问框架.与 Spring 和 Struts 组成了 Java ...

  4. 通过源码分析MyBatis的缓存

    前方高能! 本文内容有点多,通过实际测试例子+源码分析的方式解剖MyBatis缓存的概念,对这方面有兴趣的小伙伴请继续看下去~ MyBatis缓存介绍 首先看一段wiki上关于MyBatis缓存的介绍 ...

  5. Mybatis二级缓存原理

    记录是一种精神,是加深理解最好的方式之一. 最近看了下Mybatis的源码,分析了二级缓存的实现方式,在这里把他记下来.虽然这不复杂,对这方面的博客也有很多,写的也很好.但我坚信看懂了是其一,能够教别 ...

  6. mybatis的缓存机制(一级缓存二级缓存和刷新缓存)和mybatis整合ehcache

    1      查询缓存 1.1  什么是查询缓存 mybatis提供查询缓存,用于减轻数据压力,提高数据库性能. mybaits提供一级缓存,和二级缓存. 一级缓存是SqlSession级别的缓存.在 ...

  7. Mybatis一级缓存,二级缓存的实现就是这么简单

    介绍 又到了一年面试季,所以打算写一点面试常问的东西,争取说的通俗易懂.面试高级岗,如果你说熟悉Mybatis,下面这些问题基本上都会问 Mybatis插件的实现原理? 如何写一个分页插件? Myba ...

  8. (转)mybatis一级缓存二级缓存

    一级缓存 Mybatis对缓存提供支持,但是在没有配置的默认情况下,它只开启一级缓存,一级缓存只是相对于同一个SqlSession而言.所以在参数和SQL完全一样的情况下,我们使用同一个SqlSess ...

  9. Mybatis一级缓存、二级缓存

    一级缓存:SqlSession mybatis一级缓存是指在内存中开辟一块区域,用来保存用户对数据库的操作信息(sql)和数据库返回的数据,如果下一次用户再执行相同的请求,那么直接从内存中读数数据而不 ...

  10. MyBatis-学习笔记11【11.Mybatis的缓存】

    Java后端 学习路线 笔记汇总表[黑马程序员] MyBatis-学习笔记01[01.Mybatis课程介绍及环境搭建][day01] MyBatis-学习笔记02[02.Mybatis入门案例] M ...

最新文章

  1. Oracle ebs(E-Business Suite) 电子商务套件 简介
  2. python文件读写,以后就用with open语句
  3. 课程三、电子商务物流解决方案
  4. [JSOI2007]建筑抢修 (贪心)
  5. 都说Hadoop与大数据平台难懂?我就花了6分钟,但是看得明明白白
  6. Windows环境下smarty安装最简明教程 分享
  7. Spring+MyBatis企业应用实战 - 笔记
  8. java中常见英文单词_JAVA中常见的英文单词
  9. UVA 11859 Division Game[Nim游戏]
  10. 打造极致Material Design动画风格Button
  11. Nachos编译与使用--Nachos配置
  12. 实时系统动态内存算法分析dsa(二)——TLSF代码分析
  13. 硬盘常见接口类型详解
  14. LABjs分析 http://labjs.com/documentation.php#queuescript
  15. Python全栈笔记(六)
  16. c语言俩小时不挂科——全程高能,没有废话
  17. 掷骰子(python代码)
  18. JavaScript-ES6-基础语法
  19. 相对舒适的爬虫入门系列(一):手快尝鲜【requests库】
  20. 云智慧智能研究院:2022年智能运维发展八大趋势

热门文章

  1. mouse rat web net log wood alligator  crocodile  区别
  2. flutter文本展开收起
  3. 输入一个大写字母,输出小写字母和ASCII值
  4. matlab 三维数据多项式拟合,matlab多项式拟合
  5. 经济学学生学哪种计算机语言,学什么语言最有用? 经济学家认为学汉语更有收益...
  6. dns2tcp搭建DNS隧道绕过校园网
  7. NSIS之Modern UI
  8. Trace32:常见问题总结
  9. @湖南信息学院莘莘学子,一起探秘中科易安联网型校园智能门锁
  10. 浏览器兼容性测试应该如何做?