MyBatis:缓存

news2025/1/23 10:44:33

MyBatis

  • 缓存
    • 一级缓存
    • 二级缓存

在这里插入图片描述

缓存

缓存,是数据交换的缓冲区(临时保存数据的地方)。即将数据(数据一般为频繁查询且不易改变)保存在计算机内存中,下次读取数据时直接从内存中获取,以避免频繁的访问数据库或磁盘文件,从而提高程序性能。

MyBatis 缓存,是 MyBatis 提供的一种优化机制,用于提高查询效率和减少与数据库的交互次数。在 MyBatis 缓存中,分为一级缓存二级缓存

一级缓存

一级缓存,是 SqlSession 级别的缓存。即在同一个 SqlSession 中,查询结果会被缓存,以供后续的查询直接使用。在 MyBatis 缓存中,只默认开启一级缓存,而二级缓存需要手动配置开启。另外,一级缓存之间是互相独立的缓存空间,不能通信。

简单示例:
1.使用同一个 SqlSession 中,第一次获取查询结果后再次进行相同的查询,只执行一次 SQL 语句
在这里插入图片描述

查看日志,结果如图:
在这里插入图片描述

2.使用同一个 SqlSession 中,第一次获取查询结果后再次进行不同的查询,执行了两次 SQL 语句(缓存中没有找到对应的结果,所以执行 SQL 语句从数据库中查找数据。当然,找到后也会放入缓存中)
在这里插入图片描述

查看日志,结果如图:
在这里插入图片描述

同一个 SqlSession 下也执行了两次 SQL 语句的其他情况:
(1)使用同一个 SqlSession 中,第一次获取查询结果后再次进行相同的查询,但两次查询之间进行清空缓存(sqlSession.clearCache();)
(2)使用同一个 SqlSession 中,第一次获取查询结果后再次进行相同的查询,但两次查询之间进行增改删操作(缓存会刷新)

3.使用不同的 SqlSession 进行相同的两次查询,执行了两次 SQL 语句
在这里插入图片描述

查看日志,结果如图:
在这里插入图片描述

二级缓存

二级缓存(全局缓存),是 mapper 级别的缓存。即可以跨越多个 SqlSession ,允许在不同的 SqlSession 之间共享查询结果,但需要在 mapper 文件中进行配置。在开启二级缓存情况下,一级缓存的数据会在会话提交或关闭前转存到二级缓存中。

简单示例:
首先,手动配置开启二级缓存。这需要在全局配置文件 mybatis.xml 中的 settings 标签内添加开启配置

<!-- 开启二级缓存 -->
<setting name="cacheEnabled" value="true"/>

接着,映射文件中需要添加 < cache /> 标签

<!-- 开启二级缓存 -->
<cache />

然后,实体类必须实现序列化接口(implements Serializable)
在这里插入图片描述

最后,测试结果。使用不同的 SqlSession 进行相同的两次查询(需要 sqlSession1 关闭),执行了一次 SQL 语句
在这里插入图片描述

查看日志,结果如图:
在这里插入图片描述

开启二级缓存需要在 MyBatis 全局配置文件中配置 cacheEnabled 值为 true 。同时在映射文件中添加 < cache /> 标签。另外,在 select 标签的 useCache 属性中,默认值为 true ,开启二级缓存后,二级缓存生效;若设置为 false ,即使开启二级缓存后也会在该 select 标签中失效。而在 select 标签的 flushCache 属性中,默认值为 false ,使用所有缓存;若设置为 true ,则禁用所有缓存。但是,在增删改标签的 flushCache 属性中,默认值为 true ,执行增删改操作后刷新所有缓存。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1303743.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

YOLOv8独家原创改进:轻量化自研设计双卷积,重新设计backbone和neck结构,完成涨点且计算量和参数量显著下降

💡💡💡本文自研创新改进:双卷积由组卷积和异构卷积组成,执行 33 和 11 卷积运算代替其他卷积核仅执行 11 卷积,YOLOv8 Conv,从而轻量化YOLOv8,性能如下表,GFLOPs 8.1降低至7.6,参数量6.3MB降低至5.8MB layers parametersGFLOPsMBYOLOv8n16830068188.16.3MByolov8_…

销售技巧培训之如何提升房地产销售技巧

在房地产销售这个竞争激烈的行业中&#xff0c;要想获得成功&#xff0c;不仅需要熟练掌握销售技巧&#xff0c;还需要不断地提升自己的能力。下面&#xff0c;我们将从以下几个方面探讨如何提升房地产销售技巧。 一、了解客户需求 倾听客户&#xff1a;在与客户沟通时&#x…

据房间Id是否存在,判断当前房间是否到期且实时更改颜色

重点代码展示&#xff1a; <template><el-col style"width: 100%;height: 100%;"><el-col :span"20"><el-card class"room_info"><avue-data-icons :option"option"></avue-data-icons></el-…

【截图版本】Linux常用指令详解

———————————————— 版权声明&#xff1a;本文为CSDN博主「小呆瓜历险记」的原创文章&#xff0c;遵循CC 4.0 BY-SA版权协议&#xff0c;转载请附上原文出处链接及本声明。 原文链接&#xff1a;https://blog.csdn.net/m0_58963318/article/details/134713282

亚信科技AntDB携手蓝凌软件,助推企业数字化办公转型升级

随着企业数字化转型的深入&#xff0c;企业对于协同办公、移动门户、数字运营、智能客服等方面的需求越来越高&#xff0c;数智化正成为催生新动能和新优势的关键力量。数字化的办公平台可以帮助企业实现各类信息、流程的集中化、数字化和智能化管理&#xff0c;为企业管理者提…

【代码随想录】算法训练计划48

dp 1、198. 打家劫舍 题目&#xff1a; 输入&#xff1a;[2,7,9,3,1] 输出&#xff1a;12 偷窃到的最高金额 2 9 1 12 。 思路&#xff1a; 只有两种情况&#xff0c;递推公式就好说了,dp[i]永远都是题意&#xff0c;就是当前偷到的最大金额 func rob(nums []int) int…

HarmonyOS自定义抽奖转盘开发(ArkTS)

介绍 本篇 Codelab 是基于画布组件、显式动画&#xff0c;实现的一个自定义抽奖圆形转盘。包含如下功能&#xff1a; 1. 通过画布组件 Canvas&#xff0c;画出抽奖圆形转盘。 2. 通过显式动画启动抽奖功能。 3. 通过自定义弹窗弹出抽中的奖品。 相关概念 ● Stack组件…

制作一个RISC-V的操作系统五-RISC-V汇编语言编程一

文章目录 RISC-V汇编语言入门汇编语言概念简介 汇编语言语法介绍&#xff08;GNU版本&#xff09; RISC-V汇编语言入门 汇编语言概念简介 高级&#xff1a;可以理解就是更贴近人的理解 低级&#xff1a;可以理解就是更贴近机器的 难移植&#xff1a;汇编指令基本上和机器指令…

线程安全的哈希表ConcurrentHashMap

1. HashTable 不推荐使用&#xff0c;无脑给各种方法加锁 2.ConcurrentHashMap 多线程下推荐使用 锁粒度控制 HashTable直接在方法上加synchronized&#xff0c;相当于对哈希表对象加锁&#xff0c;一个哈希表只有一把锁。多线程环境下&#xff0c;无论线程如何操作哈希表…

医疗设备智慧管理助力医院提质增效,阿基米德amp;健康界实践分享

近日&#xff0c;苏州阿基米德网络科技有限公司与医疗领域头部级媒体健康界&#xff0c;联合举办“数智为擎 提质增效——医学装备智慧管理创新发展论坛”的直播活动。 直播现场&#xff0c;来自上海交通大学医学院附属同仁医院、中华医学会航海医学分会、苏州阿基米德的专家们…

循序字符中插入数据(链表)

有一串已经从小到大排好序的数 2 3 5 8 9 10 18 26 32。现需要往这串数中插入 6 使其得 到的新序列仍符合从小到大排列。&#xff08;使用链表&#xff09;

Python:核心知识点整理大全14-笔记

目录 ​编辑 7.2.2 让用户选择何时退出 parrot.py 7.2.3 使用标志 7.2.4 使用 break 退出循环 cities.py 7.2.5 在循环中使用 continue counting.py 7.2.6 避免无限循环 counting.py 7.3 使用 while 循环来处理列表和字典 7.3.1 在列表之间移动元素 confirmed_user…

查询mysql服务器当前时区设置、session当前时区设置

使用命令SELECT global.time_zone;可以查询mysql服务器的当前时区设置&#xff0c;例如&#xff1a; 使用命令SELECT session.time_zone;可以查询session的当前时区设置&#xff0c;例如&#xff1a;

2023年全国职业院校技能大赛信息安全管理与评估赛项正式赛(模块一)GZ032

全国职业院校技能大赛高等职业教育组 信息安全管理与评估 任务书 模块一 网络平台搭建与设备安全防护 极安云科专注技能竞赛&#xff0c;包含网络建设与运维和信息安全管理与评估两大赛项&#xff0c;及各大CTF&#xff0c;基于两大赛项提供全面的系统性培训&#xff0c;拥…

Linux常用命令---- test 命令

文章目录 基本语法文件测试检查文件是否存在检查文件是否是目录检查文件是否为空检查文件是否可读、可写或可执行 字符串测试检查字符串是否为空检查字符串是否相等检查字符串是否不相等 数字测试检查数字是否相等检查数字是否大于或小于 在Linux操作系统中&#xff0c;test命令…

59.计算机网络笔记

以上仅供参考&#xff0c;不一定对的&#xff0c;毕竟网络又不是我的学习方向。 一、路由器、交换机、网关。 交换机只会关心数据包的mac地址&#xff0c;不关心数据包的ip地址。 tcp/ip协议规定&#xff0c;不同子网之间是不可以直接通信的&#xff0c;如果要通信需要通过网关…

手动搭建koa+ts项目框架(日志篇)

文章目录 前言一、安装koa-logger二、引入koa-logger并使用总结如有启发&#xff0c;可点赞收藏哟~ 前言 本文基于手动搭建koats项目框架&#xff08;路由篇&#xff09;新增日志记录 一、安装koa-logger npm i -S koa-onerror and npm i -D types/koa-logger二、引入koa-lo…

大数据可视化推荐项目——基于Python/Django的电影评论可视化分析推荐系统的设计与实现

大数据可视化推荐项目——基于Python/Django的电影评论可视化分析推荐系统的设计与实现 技术栈&#xff1a;大数据爬虫/机器学习算法/数据分析与挖掘/大数据echarts可视化/Django框架/Mysql 摘要&#xff1a;本文介绍了一个基于大数据可视化的电影评论分析推荐系统&#xff0…

Clickhouse RoaringBitmap

https://blog.csdn.net/penriver/article/details/119736050 https://juejin.cn/post/7179956435806076988 BitMap适合连续密集的正整数存储&#xff0c;对于稀疏的正整数存储&#xff0c;其性能在很多时候是没办法和int数组相比的&#xff0c;尤其是正整数跨度较大的场景&…

python:五种算法(GWO、HHO、WOA、PSO、SSA)求解23个测试函数(python代码)

一、五种算法简介 1、灰狼优化算法GWO 2、哈里斯鹰优化算法HHO 3、鲸鱼优化算法WOA 4、粒子群优化算法PSO 5、麻雀搜索算法SSA 二、5种算法求解23个函数 &#xff08;1&#xff09;23个函数简介 参考文献&#xff1a; [1] Yao X, Liu Y, Lin G M. Evolutionary program…