简介

什么是缓存

**将一次查询的结果暂存至内存,后续查询只需查询缓存**

为什么使用缓存

**减少与数据库的交互次数,减少系统开销,提高系统效率**

什么样的数据能使用缓存

**经常查询且不常修改的数据**

Mybatis缓存

一级缓存

也叫本地缓存,默认开启,无法关闭,只在一次SqlSession中有效(拿到连接->关闭连接),底层由【Map】实现数据存储

  • 与数据库同一次会话期间查询到的数据会放在本地缓存中
  • 若之后需要获取相同数据,直接从缓存中获取
    <select id="queryUserById" resultType="User">
SELECT * FROM user WHERE id = #{id};
</select> <update id="updateUser" parameterType="User">
UPDATE user set name = #{name}, pwd = #{pwd} WHERE id = #{id};
</update>
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
User user = mapper.queryUserById(1);
User user2 = mapper.queryUserById(1); System.out.println(user == user2);
sqlSession.close();
  • 日志输出SQL语句仅执行一次,且输出结果为true,表明两个user实例对象为同一个
sqlSession.getMapper(UserMapper.class);
User user = mapper.queryUserById(1); User iris = new User(1, "Iris", "123");
mapper.updateUser(iris); User user2 = mapper.queryUserById(1);
System.out.println(user == user2);
  • 在修改数据库数据(哪怕不是目标记录)后再次查询会重新访问数据库

【缓存失效原因】

  • 查询不同的记录
  • 查询不同的Mapper
  • 不同线程查询
  • 增删改操作均可能导致缓存刷新
  • 手动清除

二级缓存

需在核心配置文件中打开缓存【即使默认开启】,才能手动配置缓存属性

开启全局缓存(手动显示开启)

<setting name="cacheEnabled" value="true"/>

全局缓存,由于一级缓存作用域太低从而产生,基于namespace级别的缓存,二级缓存会将每次会话的一次缓存出保存至二级缓存,不同mapper所查询的数据放在其对应缓存【Map】中

二级缓存由标签cache实现,其中可设置相关属性:

  • 缓存策略

    • LRU【默认】:最近最少使用(移除最长时间不被使用的对象)
    • FIFO:先进先出(按对象进入缓存的顺序来移除它们)
    • SOFT:软引用(基于垃圾回收器状态和软引用规则移除对象)
    • WEAK:弱引用(更积极地基于垃圾收集器状态和弱引用规则移除对象)
  • 缓存刷新间隔(ms)
  • 引用数目【默认为1024个对象】
  • 是否仅可读【默认可读写】

    下面的示例创建了一个FIFO缓存,间隔60刷新,最多存储512个对象且返回的对象仅可读
<cache
eviction="FIFO"
flushInterval="60000"
size="512"
readOnly="true"/>

测试二级缓存是否有效

    SqlSession sqlSession = MybatisUtils.getSqlSession();
SqlSession sqlSession2 = MybatisUtils.getSqlSession(); UserMapper mapper = sqlSession.getMapper(UserMapper.class);
UserMapper mapper2 = sqlSession2.getMapper(UserMapper.class); User user = mapper.queryUserById(1);
System.out.println(user);
sqlSession.close(); User user2 = mapper2.queryUserById(1);
System.out.println(user2); System.out.println(user == user2);
sqlSession2.close();

【结果输出:true】意为sqlSqssion2在sqlSession关闭后从二级缓存中获取到了sqlSession存入的数据。

报错【对象未序列】的解决方法

  • 实例对象继承Serializable

    public class User implements Serializable
  • 设置缓存对象仅可读(mapper.xml中)

    readOnly="true"

小结

  • 只要开启二级缓存,在相同Mapper下均有效
  • 所有数据都会先放在一级缓存中
  • 只有当会话提交/关闭,数据才转存至二级缓存中

Mybatis缓存原理

Mybatis学习笔记-缓存的更多相关文章

  1. Mybatis学习笔记导航

    Mybatis小白快速入门 简介 本人是一个Java学习者,最近才开始在博客园上分享自己的学习经验,同时帮助那些想要学习的uu们,相关学习视频在小破站的狂神说,狂神真的是我学习到现在觉得最GAN的老师 ...

  2. mybatis学习笔记(14)-查询缓存之中的一个级缓存

    mybatis学习笔记(14)-查询缓存之中的一个级缓存 标签: mybatis mybatis学习笔记14-查询缓存之中的一个级缓存 查询缓存 一级缓存 一级缓存工作原理 一级缓存測试 一级缓存应用 ...

  3. mybatis学习笔记之基础框架(2)

    mybatis学习笔记之基础框架(2) mybatis是一个持久层的框架,是apache下的顶级项目. mybatis让程序将主要精力放在sql上,通过mybatis提供的映射方式,自由灵活生成满足s ...

  4. mybatis学习笔记之学习目录(1)

    mybatis学习笔记之学习结构(1) 学习结构: 1.mybatis开发方法 原始dao开发方法(程序需要编写dao接口和dao实现类) mybatis的mapper接口(相当于dao接口)代理开发 ...

  5. Mybatis学习笔记汇总(包括源码和jar包)

    博客整理 Mybatis学习笔记(一)--对原生jdbc中问题的总结 Mybatis学习笔记(二)--Mybatis框架 Mybatis学习笔记(三)--入门程序 MyBatis学习笔记(四)--入门 ...

  6. 【MyBatis学习笔记】

    [MyBatis学习笔记]系列之预备篇一:ant的下载与安装 [MyBatis学习笔记]系列之预备篇二:ant入门示例 [MyBatis学习笔记]系列之一:MyBatis入门示例 [MyBatis学习 ...

  7. Mybatis学习笔记(二) 之实现数据库的增删改查

    开发环境搭建 mybatis 的开发环境搭建,选择: eclipse j2ee 版本,mysql 5.1 ,jdk 1.7,mybatis3.2.0.jar包.这些软件工具均可以到各自的官方网站上下载 ...

  8. MyBatis:学习笔记(3)——关联查询

    MyBatis:学习笔记(3)--关联查询 关联查询 理解联结 SQL最强大的功能之一在于我们可以在数据查询的执行中可以使用联结,来将多个表中的数据作为整体进行筛选. 模拟一个简单的在线商品购物系统, ...

  9. MyBatis:学习笔记(1)——基础知识

    MyBatis:学习笔记(1)--基础知识 引入MyBatis JDBC编程的问题及解决设想 ☐ 数据库连接使用时创建,不使用时就释放,频繁开启和关闭,造成数据库资源浪费,影响数据库性能. ☐ 使用数 ...

随机推荐

  1. 重新整理 .net core 实践篇—————HttpClientFactory[三十二]

    前言 简单整理一下HttpClientFactory . 正文 这个HttpFactory 主要有下面的功能: 管理内部HttpMessageHandler 的生命周期,灵活应对资源问题和DNS刷新问 ...

  2. 基于ABP落地领域驱动设计-06.正确区分领域逻辑和应用逻辑

    目录 系列文章 领域逻辑和应用逻辑 多应用层 示例:正确区分应用逻辑和领域逻辑 学习帮助 系列文章 基于ABP落地领域驱动设计-00.目录和前言 基于ABP落地领域驱动设计-01.全景图 基于ABP落 ...

  3. Centos7.5使用SSH密钥登录

    12.1.查看操作系统版本 # cat /etc/redhat-release CentOS Linux release 7.5.1804 (Core) 12.2.在服务器端创建密钥 # ssh-ke ...

  4. 31、DNS介绍

    [root@centos6 ~]# dig @8.8.8.8 www.baidu.com +trace ; <<>> DiG 9.8.2rc1-RedHat-9.8.2-0.3 ...

  5. POJ 1082 Calendar Game 原来这题有个超简单的规律

    万能的discuss.只需要月份和天数同奇同偶即可,9月30和11月30例外 #include <iostream> #include <cstdio> using names ...

  6. AcWing 1127. 香甜的黄油

    农夫John发现了做出全威斯康辛州最甜的黄油的方法:糖. 把糖放在一片牧场上,他知道 N 只奶牛会过来舔它,这样就能做出能卖好价钱的超甜黄油. 当然,他将付出额外的费用在奶牛上. 农夫John很狡猾, ...

  7. shell 重定向以及文件描述符

    1.对重定向的理解 Linux Shell 重定向分为两种,一种输入重定向,一种是输出重定向:从字面上理解,输入输出重定向就是「改变输入与输出的方向」的意思. 输入方向就是数据从哪里流向程序.标准输入 ...

  8. 什么是 Acunetix 目标知识库

    随着Acunetix 的最新更新,我们引入了一个称为目标知识库的新功能.每次扫描目标时,Acunetix 都会收集并存储有关它的信息.此信息包括构成站点结构的路径.表单的位置及其输入.Web 应用程序 ...

  9. WPF教程八:如何更好的使用Application程序集资源

    这一篇单独拿出来分析这个程序集资源,为的就是不想让大家把程序集资源和exe程序强关联,因为程序集资源实际上是二进制资源,后续编译过程中会被嵌入到程序集中,而为了更方便的使用资源,我们要好好梳理一下程序 ...

  10. OpenMVG 系列 (2):Image 和 Numeric

    OpenMVG 的功能模块由若干核心库组成,本文主要介绍 Image 和 Numeric 两个库 1  Image Image 库包含图像容器 Image<T>.图像IO读写函数 Read ...