深入理解 MyBatis 的缓存机制:一级缓存与二级缓存
MyBatis 是目前 Java 开发中常用的一种 ORM(对象关系映射)框架,它不仅简化了 SQL 语句的编写和管理,还提供了强大的缓存机制,用以提高数据库访问的性能。MyBatis 的缓存分为一级缓存和二级缓存,分别应用于不同的层次和场景。在本文中,我们将深入探讨 MyBatis 的缓存机制,包括一级缓存、二级缓存的原理、工作机制及其在应用中的优势和注意事项。
目录
- 什么是 MyBatis 缓存?
- 一级缓存
- 一级缓存的实现原理
- 一级缓存的作用范围
- 二级缓存
- 二级缓存的实现原理
- 如何启用二级缓存
- 一级缓存与二级缓存的区别
- 缓存的作用与限制
- MyBatis 缓存最佳实践
- 小结
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共享缓存结果,则需要启用二级缓存。
一级缓存会在以下情况下失效:
- 执行
update、insert、delete等操作,修改了数据库中的数据。 - 执行了
SqlSession的clearCache()方法。 - 当前
SqlSession被关闭,一级缓存也随之被销毁。
3. 二级缓存
3.1 二级缓存的实现原理
二级缓存的作用范围是Mapper 映射级别,多个 SqlSession 可以共享同一个 Mapper 的二级缓存。它是通过将查询的结果持久化存储到内存中来实现的,通常使用 HashMap 或其他第三方缓存框架(如 EhCache、Redis)作为存储介质。
二级缓存需要手动开启,可以通过以下步骤启用:
- 在
mybatis-config.xml配置文件中开启全局的二级缓存支持:<settings><setting name="cacheEnabled" value="true"/> </settings> - 在需要启用二级缓存的 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都可以访问。 - 为了保证数据的一致性,
update、insert、delete等操作执行后,会清空相关的缓存数据。
- 只有在
4. 一级缓存与二级缓存的区别
-
缓存作用范围:
- 一级缓存:作用范围是
SqlSession,只在当前会话中有效。 - 二级缓存:作用范围是
Mapper级别,多个SqlSession可以共享。
- 一级缓存:作用范围是
-
生命周期:
- 一级缓存:随着
SqlSession的生命周期结束而结束。 - 二级缓存:在
SqlSession结束后,数据会存入持久化缓存中,并能被其他SqlSession共享。
- 一级缓存:随着
-
默认启用状态:
- 一级缓存:默认开启。
- 二级缓存:默认关闭,需要手动配置。
5. 缓存的作用与限制
5.1 缓存的作用
- 减少数据库访问:通过缓存查询结果,可以显著减少数据库的访问频率,从而提高系统性能。
- 提高数据访问速度:由于缓存的数据存储在内存中,读取速度比访问数据库要快得多。
5.2 缓存的限制
- 一致性问题:当数据库中的数据发生变化时,缓存中的数据可能会变得不一致,因此需要设置合适的缓存失效机制。
- 适用场景有限:缓存适合那些读多写少的场景,在频繁写操作的场景中,缓存的更新会带来额外的性能消耗。
6. MyBatis 缓存最佳实践
- 确保数据的一致性:在频繁写操作的场景中,不推荐启用缓存。缓存可以带来读性能的提升,但必须谨慎对待数据的一致性问题。
- 合理设置缓存策略:通过设置合适的失效时间和过期策略,可以在保证性能的同时避免缓存带来的数据不一致问题。
- 结合第三方缓存框架:可以使用 Redis、EhCache 等第三方缓存框架来增强二级缓存的性能和管理能力。
7. 小结
MyBatis 的缓存机制为开发者提供了有效提高查询效率的工具。一级缓存默认开启,作用范围是 SqlSession,而 二级缓存需要手动配置,作用范围是 Mapper。二级缓存使得不同的会话之间可以共享查询结果,进一步减少数据库访问频率。
在实际开发中,合理使用缓存机制可以显著提高应用的性能,但需要注意数据的一致性问题,特别是在涉及频繁的写操作时,使用缓存必须非常谨慎。通过结合不同的缓存策略和第三方缓存框架,开发者可以构建出更为高效和稳定的系统。
理解并应用 MyBatis 的缓存机制,能够帮助开发人员在数据访问的性能和数据一致性之间找到良好的平衡点,从而提高系统的整体性能。
相关文章:
深入理解 MyBatis 的缓存机制:一级缓存与二级缓存
MyBatis 是目前 Java 开发中常用的一种 ORM(对象关系映射)框架,它不仅简化了 SQL 语句的编写和管理,还提供了强大的缓存机制,用以提高数据库访问的性能。MyBatis 的缓存分为一级缓存和二级缓存,分别应用于不…...
移远通信推出全新5G RedCap模组RG255AA系列,以更高性价比加速5G轻量化大规模商用
11月20,全球领先的物联网整体解决方案供应商移远通信宣布,正式推出其全新5G RedCap模组RG255AA系列。该系列模组支持5G NR独立组网(SA)和LTE Cat 4双模通信,具有高性能高集成度、低功耗、小尺寸、高性价比等优势&#…...
架构-微服务-环境搭建
文章目录 前言一、案例准备1. 技术选型2. 模块设计3. 微服务调用 二、创建父工程三、创建基础模块四、创建用户微服务五、创建商品微服务六、创建订单微服务 前言 微服务环境搭建 使用的电商项目中的商品、订单、用户为案例进行讲解。 一、案例准备 1. 技术选型 maven&a…...
conda下载与pip下载的区别
一、conda下载与pip下载的区别 最重要是依赖关系: pip安装包时,尽管也对当前包的依赖做检查,但是并不保证当前环境的所有包的所有依赖关系都同时满足。 当某个环境所安装的包越来越多,产生冲突的可能性就越来越大。conda会检查当…...
MySQL获取数据库内所有表格数据总数
在 MySQL 中,要获取数据库内所有表格的数据总数,可以编写一个查询脚本来遍历每个表并计算其行数。你可以使用 INFORMATION_SCHEMA 数据库,它包含了关于数据库元数据的表格,如 TABLES 和 COLUMNS。 以下是一个示例脚本,…...
Matlab 深度学习工具箱 案例学习与测试————求二阶微分方程
clc clear% 定义输入变量 x linspace(0,2,10000);% 定义网络的层参数 inputSize 1; layers [featureInputLayer(inputSize,Normalization"none")fullyConnectedLayer(10)sigmoidLayerfullyConnectedLayer(1)sigmoidLayer]; % 创建网络 net dlnetwork(layers);% 训…...
django authentication 登录注册
文章目录 前言一、django配置二、后端实现1.新建app2.编写view3.配置路由 三、前端编写1、index.html2、register.html3、 login.html 总结 前言 之前,写了django制作简易登录系统,这次利用django内置的authentication功能实现注册、登录 提示ÿ…...
三种蓝牙架构实现方案
一、蓝牙架构方案 1、hostcontroller双芯片标准架构 手机里面包含很多SoC或者模块,每颗SoC或者模块都有自己独有的功能,比如手机应用跑在AP芯片上,显示屏,3G/4G通信,WiFi/蓝牙等都有自己专门的SoC或者模块࿰…...
ffmpeg 视频滤镜:高斯模糊-gblur
滤镜描述 gblur 官网地址 > FFmpeg Filters Documentation 这个滤镜会将视频变得模糊。 滤镜使用 参数 gblur AVOptions:sigma <float> ..FV.....T. set sigma (from 0 to 1024) (default 0.5)steps <int> ..FV.....T…...
期权懂|在期权市场中,如何用好双买期权?
期权小懂每日分享期权知识,帮助期权新手及时有效地掌握即市趋势与新资讯! 在期权市场中,如何用好双买期权? 期权双买操作,即同时买入认购期权(看涨期权)和认沽期权(看跌期权…...
【Linux学习】【Ubuntu入门】2-3 make工具和makefile引入
1.使用命令新建三个.c文件vi main.c,vi input.c,vi caclcu.c,两个.h文件vi input.h,vi caclcu.h 2.vi Makefile:新建Makefile文件,输入一下内容 注意:命令列表中每条命令前用TAB键,不…...
《黑神话:悟空》游戏辅助修改器工具下载指南与操作方法详解
《黑神话:悟空》是一款备受期待的动作冒险游戏,目前尚未正式发布。游戏开发团队一直在强调游戏的完整性和公平性,因此官方并不支持任何形式的作弊或修改行为。然而,对于一些玩家而言,使用辅助修改器可能会成为他们体验…...
C语言菜鸟入门·关键字·union的用法
目录 1. 简介 2. 访问成员 2.1 声明 2.2 赋值 3. 共用体的大小 4. 与typedef联合使用 5. 更多关键字 1. 简介 共用体(union)是一种数据结构,它允许在同一内存位置存储不同的数据类型,但每次只能存储其中一种类型的…...
ensp静态路由实验
一、实验目的 1、熟练掌握交换机的基本配置命令 2、熟练掌握静态路由的使用方法 3. 熟练掌握交换机端口模式 二、实验内容 需求: 根据要求利用现有实验设备组建小型局域网 实验设备: 交换机S37002台;PC机2台;路由器2台。 …...
构建 Java Web 应用程序:从 Servlet 到数据库交互(Eclipse使用JDBC连接Mysql数据库)
第 1 部分:环境设置 安装 Java Development Kit (JDK):下载并安装 JDK。设置 IDE:安装并配置 IDE(如 IntelliJ IDEA 或 Eclipse)。安装数据库:下载并安装 MySQL 数据库。配置数据库:创建数据库…...
mfc100u.dll是什么?分享几种mfc100u.dll丢失的解决方法
mfc100u.dll 是一个动态链接库(DLL)文件,属于 Microsoft Foundation Classes (MFC) 库的一部分。MFC 是微软公司开发的一套用于快速开发 Windows 应用程序的 C 类库。mfc100u.dll 文件包含了 MFC 库中一些常用的函数和类的定义,这…...
Java面试之多线程并发篇
前言 本来想着给自己放松一下,刷刷博客,突然被几道面试题难倒!说一说自己对于 synchronized 关键字的了解?说说自己是怎么使用 synchronized 关键字?什么是线程安全?Vector是一个线程安全类吗?…...
视频推拉流EasyDSS互联网直播点播平台技术特点及应用场景剖析
在数字科技日新月异的今天,视频直播和点播已经成为互联网内容传播的重要方式之一。而互联网直播点播平台EasyDSS作为功能强大的流媒体直播点播视频能力平台,提供了一站式的视频推拉流、转码、直播、点播、时移回放、存储等视频服务,广泛应用于…...
安全加固方案
交换机安全加固 查看是否关闭未使用的接口 25GE1/0/1、25GE1/0/47、25GE1/0/48需要使用,暂不关闭 system-view # interface Eth-Trunk99 shutdown quit interface Eth-Trunk100 shutdown quit interface Eth-Trunk110 shutdown quit interface 25GE1/…...
Linux firewall防火墙规则
官网 https://firewalld.org/ 查看所有防火墙规则: firewall-cmd --list-all-zones查看当前区域防火墙规则: firewall-cmd --list-all添加一个开放服务规则: firewall-cmd --add-servicessh删除一个开放服务规则: firewall-cmd…...
日语AI面试高效通关秘籍:专业解读与青柚面试智能助攻
在如今就业市场竞争日益激烈的背景下,越来越多的求职者将目光投向了日本及中日双语岗位。但是,一场日语面试往往让许多人感到步履维艰。你是否也曾因为面试官抛出的“刁钻问题”而心生畏惧?面对生疏的日语交流环境,即便提前恶补了…...
OpenLayers 可视化之热力图
注:当前使用的是 ol 5.3.0 版本,天地图使用的key请到天地图官网申请,并替换为自己的key 热力图(Heatmap)又叫热点图,是一种通过特殊高亮显示事物密度分布、变化趋势的数据可视化技术。采用颜色的深浅来显示…...
Netty从入门到进阶(二)
二、Netty入门 1. 概述 1.1 Netty是什么 Netty is an asynchronous event-driven network application framework for rapid development of maintainable high performance protocol servers & clients. Netty是一个异步的、基于事件驱动的网络应用框架,用于…...
【C++进阶篇】智能指针
C内存管理终极指南:智能指针从入门到源码剖析 一. 智能指针1.1 auto_ptr1.2 unique_ptr1.3 shared_ptr1.4 make_shared 二. 原理三. shared_ptr循环引用问题三. 线程安全问题四. 内存泄漏4.1 什么是内存泄漏4.2 危害4.3 避免内存泄漏 五. 最后 一. 智能指针 智能指…...
MySQL 主从同步异常处理
阅读原文:https://www.xiaozaoshu.top/articles/mysql-m-s-update-pk MySQL 做双主,遇到的这个错误: Could not execute Update_rows event on table ... Error_code: 1032是 MySQL 主从复制时的经典错误之一,通常表示ÿ…...
针对药品仓库的效期管理问题,如何利用WMS系统“破局”
案例: 某医药分销企业,主要经营各类药品的批发与零售。由于药品的特殊性,效期管理至关重要,但该企业一直面临效期问题的困扰。在未使用WMS系统之前,其药品入库、存储、出库等环节的效期管理主要依赖人工记录与检查。库…...
基于单片机的宠物屋智能系统设计与实现(论文+源码)
本设计基于单片机的宠物屋智能系统核心是实现对宠物生活环境及状态的智能管理。系统以单片机为中枢,连接红外测温传感器,可实时精准捕捉宠物体温变化,以便及时发现健康异常;水位检测传感器时刻监测饮用水余量,防止宠物…...
【1】跨越技术栈鸿沟:字节跳动开源TRAE AI编程IDE的实战体验
2024年初,人工智能编程工具领域发生了一次静默的变革。当字节跳动宣布退出其TRAE项目(一款融合大型语言模型能力的云端AI编程IDE)时,技术社区曾短暂叹息。然而这一退场并非终点——通过开源社区的接力,TRAE在WayToAGI等…...
CSS 工具对比:UnoCSS vs Tailwind CSS,谁是你的菜?
在现代前端开发中,Utility-First (功能优先) CSS 框架已经成为主流。其中,Tailwind CSS 无疑是市场的领导者和标杆。然而,一个名为 UnoCSS 的新星正以其惊人的性能和极致的灵活性迅速崛起。 这篇文章将深入探讨这两款工具的核心理念、技术差…...
当下AI智能硬件方案浅谈
背景: 现在大模型出来以后,打破了常规的机械式的对话,人机对话变得更聪明一点。 对话用到的技术主要是实时音视频,简称为RTC。下游硬件厂商一般都不会去自己开发音视频技术,开发自己的大模型。商用方案多见为字节、百…...
