Mybatis一二级缓存的实验验证

简介: Mybatis提供了一级缓存和二级缓存,本文通过实验去介绍如何去了解这两个缓存的概念,具体使用先不做评论。
Mybatis提供了一级缓存和二级缓存,本文介绍如何去了解这两个缓存的概念,具体使用不做评论。
  1. 一级缓存:针对的是SqlSession,当SqlSession没有关闭时,该会话中相同的操作会被缓存。
  2. 二级缓存:针对的是命名空间,需要手动声明<cache/>开启二级缓存,二级缓存是当SqlSession关闭后,会将一级缓存的内容放置到二级缓存中。

一级缓存是默认开启的

我们先看配置文件中的一个标签:

<settings>
    <setting name="localCacheScope" value="SESSION"/>
</settings>

在Mybatis配置文件中的<settings>标签中有这样一个name子标签localCacheScope,它说明了一级缓存默认是针对Session的:

子标签名称 描述 取值 默认
localCacheScope MyBatis 利用本地缓存机制(Local Cache)防止循环引用和加速重复的嵌套查询。 默认值为 SESSION,会缓存一个会话中执行的所有查询。 若设置值为 STATEMENT,本地缓存将仅用于执行语句,对相同 SqlSession 的不同查询将不会进行缓存。 SESSION / STATEMENT SESSION

实验

  1. 这个setting我们不配置,采用Mybatis默认的即可
  2. 我们通过sqlSessionFactory获得两个不同的sqlSession
  3. 通过sqlSession连续操作两次同样的操作,去判断其值是否相同
// 获得两个不同的Session
SqlSession sqlSession = sqlSessionFactory.openSession();
SqlSession sqlSession2 = sqlSessionFactory.openSession();
DepartmentMapper departmentMapper = sqlSession.getMapper(DepartmentMapper.class);
DepartmentMapper departmentMapper2 = sqlSession2.getMapper(DepartmentMapper.class);

Department department = departmentMapper.findById("18ec781fbefd727923b0d35740b177ab");
Department department2 = departmentMapper.findById("18ec781fbefd727923b0d35740b177ab");
System.out.println("department == department2 : " + (department == department2));

Department department3 = departmentMapper2.findById("18ec781fbefd727923b0d35740b177ab");
Department department4 = departmentMapper2.findById("18ec781fbefd727923b0d35740b177ab");
System.out.println("department3 == department4 : " + (department3 == department4));

输出结果如下,如果我们使用LOG模式打印的话,也可以看到两个sqlSession做的不同的findByID操作仅仅发送给给了两次sql,表示一级默认缓存是起作用的:

department == department2 : true
department3 == department4 : true

二级缓存的开启

默认情况下,只启用了本地的会话缓存,它仅仅对一个会话中的数据进行缓存。要启用全局的二级缓存,很简单,只需要在对应的映射mapper文件中声明标签<cache/>

但是请注意两个点:

  1. 缓存会被视为读/写缓存,这意味着获取到的对象并不是共享的,可以安全地被调用者修改,而不干扰其他调用者或线程所做的潜在修改。
  2. 二级缓存(命名空间的缓存)是由一级缓存提供的,这个提供动作是sqlSession.close()
SqlSession sqlSession = sqlSessionFactory.openSession();
SqlSession sqlSession2 = sqlSessionFactory.openSession();
DepartmentMapper departmentMapper = sqlSession.getMapper(DepartmentMapper.class);
DepartmentMapper departmentMapper2 = sqlSession2.getMapper(DepartmentMapper.class);

Department department = departmentMapper.findById("18ec781fbefd727923b0d35740b177ab");
Department department2 = departmentMapper.findById("18ec781fbefd727923b0d35740b177ab");
System.out.println("department == department2 : " + (department == department2));

sqlSession.close(); // 注意这里!!

Department department3 = departmentMapper2.findById("18ec781fbefd727923b0d35740b177ab");
Department department4 = departmentMapper2.findById("18ec781fbefd727923b0d35740b177ab");
System.out.println("department3 == department4 : " + (department3 == department4));

注意看我们添加的sqlSession.close(); 它将sqlSession的一级缓存推送到了二级缓存,那么如果我在命名空间DepartmentMapper.xml中执行的操作,都会在<cache/>中被保存下来,由于departmentdepartment2使用的是一级缓存,所以它们还是相等的。而department3department4使用的是二级缓存得到的结果,所以它们并不相等,还记得我们说的第一个注意点吗,回去看看。二级缓存的效果就是,它也不会发送sql语句,能直接命中结果。

输出结果如下:

department == department2 : true
department3 == department4 : false
目录
相关文章
|
4月前
|
缓存 Java 数据库连接
mybatis复习05,mybatis的缓存机制(一级缓存和二级缓存及第三方缓存)
文章介绍了MyBatis的缓存机制,包括一级缓存和二级缓存的配置和使用,以及如何整合第三方缓存EHCache。详细解释了一级缓存的生命周期、二级缓存的开启条件和配置属性,以及如何通过ehcache.xml配置文件和logback.xml日志配置文件来实现EHCache的整合。
mybatis复习05,mybatis的缓存机制(一级缓存和二级缓存及第三方缓存)
|
29天前
|
缓存 Java 数据库连接
MyBatis缓存机制
MyBatis提供两级缓存机制:一级缓存(Local Cache)默认开启,作用范围为SqlSession,重复查询时直接从缓存读取;二级缓存(Second Level Cache)需手动开启,作用于Mapper级别,支持跨SqlSession共享数据,减少数据库访问,提升性能。
32 1
|
1月前
|
缓存 Java 数据库连接
深入探讨:Spring与MyBatis中的连接池与缓存机制
Spring 与 MyBatis 提供了强大的连接池和缓存机制,通过合理配置和使用这些机制,可以显著提升应用的性能和可扩展性。连接池通过复用数据库连接减少了连接创建和销毁的开销,而 MyBatis 的一级缓存和二级缓存则通过缓存查询结果减少了数据库访问次数。在实际应用中,结合具体的业务需求和系统架构,优化连接池和缓存的配置,是提升系统性能的重要手段。
53 4
|
2月前
|
SQL 缓存 Java
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
本文详细介绍了MyBatis的各种常见用法MyBatis多级缓存、逆向工程、分页插件 包括获取参数值和结果的各种情况、自定义映射resultMap、动态SQL
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
|
2月前
|
SQL 缓存 Java
MyBatis如何关闭一级缓存(分注解和xml两种方式)
MyBatis如何关闭一级缓存(分注解和xml两种方式)
86 5
|
7月前
|
SQL 缓存 Java
MYBATIS缓存
MYBATIS缓存
|
3月前
|
缓存 Java 数据库连接
使用MyBatis缓存的简单案例
MyBatis 是一种流行的持久层框架,支持自定义 SQL 执行、映射及复杂查询。本文介绍了如何在 Spring Boot 项目中集成 MyBatis 并实现一级和二级缓存,以提高查询性能,减少数据库访问。通过具体的电商系统案例,详细讲解了项目搭建、缓存配置、实体类创建、Mapper 编写、Service 层实现及缓存测试等步骤。
|
6月前
|
SQL 缓存 Java
【面试官】Mybatis缓存有什么问题吗?
面试官:你说下对MyBatis的理解?面试官:那SqlSession知道吧?面试官:Mybatis的缓存有哪几种?面试官:那Mybatis缓存有什么问题吗?面试官:Mybatis分页插件是怎么
【面试官】Mybatis缓存有什么问题吗?
|
6月前
|
缓存 算法 Java
关于MyBatis的缓存详解
MyBatis 的缓存机制非常灵活,可以通过简单的配置来满足不同的性能需求。合理地使用缓存可以显著提高应用程序的性能,尤其是在处理大量数据库查询时。然而,开发者需要注意缓存的一致性和并发问题,特别是在使用可读写缓存时。
|
5月前
|
域名解析 存储 缓存
破解 DNS 缓存的秘密:一个简单实验揭示定时刷新背后的惊人真相!
【8月更文挑战第27天】本文介绍DNS缓存管理的重要性及其实现方法。DNS缓存用于快速响应重复的域名解析请求,但因IP地址变动需定期刷新以确保信息准确。文章提供一个基于Python的示例脚本,模拟DNS缓存刷新过程,包括添加、查询记录以及清除过期项等功能。尽管实际环境中这些任务常由专业DNS服务软件自动处理,但该示例有助于理解DNS缓存的工作机制及其维护策略。
92 0