深入理解 MyBatis 的缓存机制:一级缓存与二级缓存

devtools/2024/11/26 19:19:42/

MyBatis 是目前 Java 开发中常用的一种 ORM(对象关系映射)框架,它不仅简化了 SQL 语句的编写和管理,还提供了强大的缓存机制,用以提高数据库访问的性能。MyBatis 的缓存分为一级缓存二级缓存,分别应用于不同的层次和场景。在本文中,我们将深入探讨 MyBatis 的缓存机制,包括一级缓存、二级缓存的原理、工作机制及其在应用中的优势和注意事项。

目录

  1. 什么是 MyBatis 缓存
  2. 一级缓存
  3. 二级缓存
  4. 一级缓存与二级缓存的区别
  5. 缓存的作用与限制
  6. MyBatis 缓存最佳实践
  7. 小结

1. 什么是 MyBatis 缓存

在应用程序开发中,数据库的查询通常是性能瓶颈之一。为了解决这一问题,MyBatis 提供了 缓存机制,将查询的结果保存到内存中,后续相同的查询可以直接从缓存中获取,从而减少对数据库的访问,提升系统性能。

MyBatis 的缓存机制分为两级:

  • 一级缓存:作用范围是SqlSession,同一 SqlSession 内多次执行相同的查询会缓存结果。
  • 二级缓存:作用范围是Mapper 映射级别,同一个 Mapper 对象的多次查询可以共享缓存数据。

2. 一级缓存

2.1 一级缓存的实现原理

MyBatis 的一级缓存是默认开启的,每个 SqlSession 都会有一个一级缓存。一级缓存的存储介质是 HashMap,它存储了由 SQL 语句和查询参数生成的缓存键值对,查询的结果会存储在 SqlSession 对象的缓存中。

例如,在一次查询中,当执行 SQL 语句时,MyBatis 会先检查缓存中是否存在该查询的结果,如果有则直接返回;如果没有,则执行查询并将结果缓存下来,供后续使用。

2.2 一级缓存的作用范围

一级缓存的作用范围是 SqlSession

  • 同一 SqlSession:在同一个 SqlSession 中,如果多次执行相同的查询(相同的 SQL 和参数),结果会从缓存中返回,避免了多次访问数据库。
  • 不同的 SqlSession:不同的 SqlSession 对象之间不共享一级缓存,如果需要跨 SqlSession 共享缓存结果,则需要启用二级缓存

一级缓存会在以下情况下失效:

  • 执行 updateinsertdelete 等操作,修改了数据库中的数据。
  • 执行了 SqlSessionclearCache() 方法。
  • 当前 SqlSession 被关闭,一级缓存也随之被销毁。

3. 二级缓存

3.1 二级缓存的实现原理

二级缓存的作用范围是Mapper 映射级别,多个 SqlSession 可以共享同一个 Mapper 的二级缓存。它是通过将查询的结果持久化存储到内存中来实现的,通常使用 HashMap 或其他第三方缓存框架(如 EhCacheRedis)作为存储介质。

二级缓存需要手动开启,可以通过以下步骤启用:

  1. mybatis-config.xml 配置文件中开启全局的二级缓存支持:
    <settings><setting name="cacheEnabled" value="true"/>
    </settings>
    
  2. 在需要启用二级缓存的 Mapper.xml 文件中添加 <cache/> 标签:
    <mapper namespace="com.example.mapper.UserMapper"><cache/><!-- 其他的SQL映射 -->
    </mapper>
    

启用二级缓存后,查询的结果会存储在 Mapper 的缓存区域中,当其他 SqlSession 发起相同的查询时,MyBatis 会优先从缓存中获取数据。

3.2 如何启用二级缓存

以下是二级缓存的使用示例:

  • 配置二级缓存
    在对应的 Mapper.xml 文件中,添加 <cache/> 标签,示例:

    <mapper namespace="com.example.mapper.UserMapper"><cache /><select id="getUserById" resultType="User">SELECT * FROM users WHERE id = #{id}</select>
    </mapper>
    
  • 二级缓存注意事项

    • 只有在 SqlSession 被关闭后,查询的数据才会被保存到二级缓存
    • 二级缓存中的数据是全局共享的,不同 SqlSession 都可以访问。
    • 为了保证数据的一致性,updateinsertdelete 等操作执行后,会清空相关的缓存数据。

4. 一级缓存与二级缓存的区别

  1. 缓存作用范围

    • 一级缓存:作用范围是 SqlSession,只在当前会话中有效。
    • 二级缓存:作用范围是 Mapper 级别,多个 SqlSession 可以共享。
  2. 生命周期

    • 一级缓存:随着 SqlSession 的生命周期结束而结束。
    • 二级缓存:在 SqlSession 结束后,数据会存入持久化缓存中,并能被其他 SqlSession 共享。
  3. 默认启用状态

    • 一级缓存:默认开启。
    • 二级缓存:默认关闭,需要手动配置。

5. 缓存的作用与限制

5.1 缓存的作用
  • 减少数据库访问:通过缓存查询结果,可以显著减少数据库的访问频率,从而提高系统性能。
  • 提高数据访问速度:由于缓存的数据存储在内存中,读取速度比访问数据库要快得多。
5.2 缓存的限制
  • 一致性问题:当数据库中的数据发生变化时,缓存中的数据可能会变得不一致,因此需要设置合适的缓存失效机制。
  • 适用场景有限缓存适合那些读多写少的场景,在频繁写操作的场景中,缓存的更新会带来额外的性能消耗。

6. MyBatis 缓存最佳实践

  1. 确保数据的一致性:在频繁写操作的场景中,不推荐启用缓存缓存可以带来读性能的提升,但必须谨慎对待数据的一致性问题。
  2. 合理设置缓存策略:通过设置合适的失效时间和过期策略,可以在保证性能的同时避免缓存带来的数据不一致问题。
  3. 结合第三方缓存框架:可以使用 Redis、EhCache 等第三方缓存框架来增强二级缓存的性能和管理能力。

7. 小结

MyBatis 的缓存机制为开发者提供了有效提高查询效率的工具。一级缓存默认开启,作用范围是 SqlSession,而 二级缓存需要手动配置,作用范围是 Mapper。二级缓存使得不同的会话之间可以共享查询结果,进一步减少数据库访问频率。

在实际开发中,合理使用缓存机制可以显著提高应用的性能,但需要注意数据的一致性问题,特别是在涉及频繁的写操作时,使用缓存必须非常谨慎。通过结合不同的缓存策略和第三方缓存框架,开发者可以构建出更为高效和稳定的系统。

理解并应用 MyBatis 的缓存机制,能够帮助开发人员在数据访问的性能和数据一致性之间找到良好的平衡点,从而提高系统的整体性能。


http://www.ppmy.cn/devtools/137193.html

相关文章

嵌入式课程day18-C语言共用体、枚举、宏定义、条件编译

目录 十二、共用体、枚举、宏定义、条件编译 12.1共用体 12.2枚举 12.3宏定义 12.4条件编译 十二、共用体、枚举、宏定义、条件编译 12.1共用体 1多个成员共用同一块内存, 2所有成员的首地址都是一样的。 3共用体类型占据空间大小是里面占用空间最多成员所占字节数&am…

英语知识网站开发:Spring Boot框架技巧

摘要 随着信息技术在管理上越来越深入而广泛的应用&#xff0c;管理信息系统的实施在技术上已逐步成熟。本文介绍了英语知识应用网站的开发全过程。通过分析英语知识应用网站管理的不足&#xff0c;创建了一个计算机管理英语知识应用网站的方案。文章介绍了英语知识应用网站的系…

macOS上进行Ant Design Pro实战教程(一)

由于一个AI项目的前端使用了umi&#xff0c;本教程根据阿里官网上的 《Ant Design 实战教程&#xff08;beta 版&#xff09;》来实操一下&#xff0c;我使用macOS操作系统&#xff0c;VS Code 开发环境。 一、开发环境 1、安装nodejs, npm, yarn 官网上建议使用cnpm&#xf…

使用Ansible/SaltStack编写自动化运维脚本

Ansible 或SaltStack 编写自动化运维脚本时&#xff0c;目标是通过模块化、参数化、可复用的方式来实现自动化运维任务。以下是编写自动化脚本的详细流程和示例。 Ansible Ansible 使用 YAML 格式编写任务&#xff0c;称为Playbooks。它基于无代理架构&#xff0c;通过 SSH 与…

第三十九章:Grafana 概述、Docker安装与验证指南

Grafana 概述、Docker安装与验证指南 一、Grafana 概述 Grafana 是一个跨平台的开源可视化分析工具,是目前网络架构和应用分析中最流行的时序数据展示工具。它主要用于大规模指标数据的可视化展示,并支持多种数据源和丰富的可视化插件。Grafana 使用Go语言开发,具备数据监…

基于Opencv的图像处理软件

目录 一、背景及意义介绍背景意义 二、概述一、背景及意义介绍背景意义 三、论文思路解决问题 四、复现过程&#xff08;一&#xff09;图像处理模块二&#xff09;图形界面模块&#xff08;一&#xff09;图像处理模块实现步骤&#xff08;二&#xff09;图形界面模块实现步骤…

企业OA管理系统:Spring Boot技术架构与应用

3系统分析 3.1可行性分析 通过对本企业OA管理系统实行的目的初步调查和分析&#xff0c;提出可行性方案并对其一一进行论证。我们在这里主要从技术可行性、经济可行性、操作可行性等方面进行分析。 3.1.1技术可行性 本企业OA管理系统采用SSM框架&#xff0c;JAVA作为开发语言&a…

【LeetCode面试150】——228汇总区间

博客昵称&#xff1a;沈小农学编程 作者简介&#xff1a;一名在读硕士&#xff0c;定期更新相关算法面试题&#xff0c;欢迎关注小弟&#xff01; PS&#xff1a;哈喽&#xff01;各位CSDN的uu们&#xff0c;我是你的小弟沈小农&#xff0c;希望我的文章能帮助到你。欢迎大家在…