什么是Mybatis的一二级缓存?

一级缓存:

也称为 SqlSession 缓存,它存在于 SqlSession 中,只对一个会话内的数据进行缓存。如果在一个会话内多次执行同一条 SQL 查询语句,那么 MyBatis 只会在第一次查询数据库时实际执行 SQL 语句,其余查询则直接从缓存中获取数据。当会话关闭时,缓存就会被清除掉。

二级缓存:

也称为全局缓存,它存在于 SqlSessionFactory 中,多个会话之间可以共享缓存数据。当多个会话访问相同的 SQL 查询语句时,只要有一个会话查询到了数据并把结果放入二级缓存中,其他的会话就可以直接从缓存中获取数据。如果缓存中的数据过期或者数据发生变化时,MyBatis 会自动刷新缓存。

注意:

注意:在实际开发中,建议慎用缓存,特别是不要在有大量并发写操作的情况下使用缓存,以免出现数据不一致的问题。另外,需要注意的是,缓存策略是针对单表操作才有意义,多表操作通常不会考虑缓存。

相关推荐
sg_knight1 小时前
Spring 框架中的 SseEmitter 使用详解
java·spring boot·后端·spring·spring cloud·sse·sseemitter
郑州光合科技余经理3 小时前
同城系统海外版:一站式多语种O2O系统源码
java·开发语言·git·mysql·uni-app·go·phpstorm
一只乔哇噻3 小时前
java后端工程师+AI大模型开发进修ing(研一版‖day60)
java·开发语言·人工智能·学习·语言模型
Dolphin_Home3 小时前
笔记:SpringBoot静态类调用Bean的2种方案(小白友好版)
java·spring boot·笔记
hadage2334 小时前
--- redis 常见问题 ---
数据库·redis·mybatis
MetaverseMan4 小时前
Java虚拟线程实战
java
浪潮IT馆4 小时前
Tomcat运行war包的问题分析与解决步骤
java·tomcat
悟能不能悟5 小时前
Caused by: java.sql.SQLException: ORA-28000: the account is locked怎么处理
java·开发语言
_院长大人_5 小时前
MyBatis Plus 分批查询优化实战:优雅地解决 IN 参数过多问题(实操)
java·mybatis