聊聊Mybatis的缓存
记得点击"欢少的成长之路",设为星标⭐
后台点击【联系我】,申请加入优质技术学习社群
(资料图片)
大家好,我是Leo。
好久没有输出技术理论了,实在是忙。最近主要以设计系统为主了。面试刚好又倒在了Mybatis原理。今天来聊一下Mybatis的一级缓存,二级缓存。
Mybatis缓存是内存中的数据,主要是对数据库查询结果的保存,使用缓存的好处是避免频繁与数据库进行交互,提升查询的响应速度。
数据库缓存扩展聊到Mybatis缓存。我们可以扩展聊一下MySQL缓存。MySQL缓存其实与Mybatis类似,在查询的时候都会先通过查询缓存检查一下所需的数据是否存在缓存中,如果存在缓存的话就会直接返回,这样就达到了避免频繁与数据库进行交互的目的。
数据查询流程图
回归正题在学习过程中,希望大家把知识点串起来学习,这样有助力更好的学习与理解
Mybatis 缓存主要分一级缓存和二级缓存。
一级缓存一级缓存也称为本地缓存(SqlSession),属于二级缓存的子集。与数据库同一次会话期间查询到的数据会放在本地缓存中。以后如果需要获取相同的数据,直接从缓存中拿,没必要再去查询数据库。
一级缓存的缓存数据只在SqlSession内有效,它的范围有两种SESSION和STATEMENT,默认是SESSION。如果不想使用一级缓存,可以通过下列代码配置
使用SESSION,这样每次执行完一个Mapper中的语句都会将一级缓存清除。二级缓存
一级缓存作用域太低,如果多个SqlSession需要共享缓存,则就需要开启二级缓存。二级缓存也叫全局缓存,二级缓存是基于namespace级别的缓存,一个namespace对应一个二级缓存。二级缓存需要我们手动开启。
我们可以通过在 mybatis-config 文件中配置开启二级缓存。
查询顺序
Mybatis的查询顺序如下图
Mybatis查询顺序
我们可以根据上图大概介绍一下B的流程。
首先创建SqlSession会话查询一条数据,这条数据就会被放到当前会话的一级缓存中。如果当前SqlSession去执行commit操作(插入,更新,删除),那么就会清空SqlSession中的一级缓存,保证缓存中始终保存的是最新的数据,避免脏读。这个时候并不会把一级缓存更新到二级缓存,这一步操作是在关闭SqlSession时触发的。新会话查询信息,就会从二级缓存中获取数据。注意:两次查询必须在同一个SqlSession中完成,否则将不会走Mybatis的一级缓存
相反,我们在使用Mybatis作为我们的持久层框架时,也就是上图的A流程
开启二级缓存后,会使用 CachingExecutor 装饰 Executor进入一级缓存查询流程前先在CachingExecutor进行二级缓存的查询如果二级缓存没有命中的话会到一级缓存中查询最后一级缓存没有的话才会去与数据库进行查询交互生命周期二级缓存开启后,同一个 namespace 下的所有操作语句,都影响着同一个 Cache,即二级缓存被多个 SqlSession 共享,是一个全局的变量。
MyBatis 是默认关闭二级缓存的,因为对于增删改操作频繁的话,那么二级缓存形同虚设,每次都会被清空缓存。
一级缓存没有过期时间,只有生命周期。MyBatis在开启一个数据库会话时,会创建一个新的SqlSession对象,SqlSession对象中会有一个Executor对象,Executor对象中持有一个PerpetualCache对象。当会话结束时,SqlSession对象及其内部的Executor对象还有PerpetualCache对象也一并释放掉。
二级缓存有过期时间,但没有后台线程进行检测。需要注意的是,并不是key-value的过期时间,而是这个cache的过期时间,是flushInterval,意味着整个清空缓存cache,所以不需要后台线程去定时检测。每当存取数据的时候,都有检测一下cache的生命时间,默认是1小时,如果这个cache存活了一个小时,那么将整个清空一下。
相关阅读
-
暴雨来袭,聚力守家园——深圳防汛救灾...
新华社深圳9月8日电(记者王丰、毛思倩、白瑜)水库开始排洪、多个主城 -
水痘的预防措施是什么(水痘的预防措施)
来为大家解答以上的问题。水痘的预防措施是什么,水痘的预防措施这个很 -
男子河边用钢筋磨针坚持2000多天
00:08近日,陕西西安。一短视频博主每天打卡河边磨“针”,已经坚持... -
凯恩:看到英格兰队友获得冠军,我也想...
目前拜仁中锋凯恩正在随英格兰代表队备战比赛,在本周五的采访中,凯恩 -
营造沉浸式潮玩体验场
国内“潮玩第一股”泡泡玛特近日宣布,国内首个潮玩行业沉浸式IP主... -
黍离原文及翻译注音 黍离原文
1、彼黍离离,彼稷之苗。2、行迈靡靡,中心摇摇。3、知我者,谓我心忧
精彩放送
-
罗莱超柔研究院&超柔战略联盟正式成立
9月21日,罗莱超柔床品在新疆赛里木湖畔举办的《寻源自然超柔无边—... -
暴雨来袭,聚力守家园——深圳防汛救灾...
新华社深圳9月8日电(记者王丰、毛思倩、白瑜)水库开始排洪、多个主城 -
水痘的预防措施是什么(水痘的预防措施)
来为大家解答以上的问题。水痘的预防措施是什么,水痘的预防措施这个很 -
男子河边用钢筋磨针坚持2000多天
00:08近日,陕西西安。一短视频博主每天打卡河边磨“针”,已经坚持... -
凯恩:看到英格兰队友获得冠军,我也想...
目前拜仁中锋凯恩正在随英格兰代表队备战比赛,在本周五的采访中,凯恩 -
营造沉浸式潮玩体验场
国内“潮玩第一股”泡泡玛特近日宣布,国内首个潮玩行业沉浸式IP主... -
黍离原文及翻译注音 黍离原文
1、彼黍离离,彼稷之苗。2、行迈靡靡,中心摇摇。3、知我者,谓我心忧 -
互联网造车大撤退,百度、滴滴隐身了,...
而随着2024年的deadline迫近,最近,小米造车有了实质性进展的消息, -
2022年的今天,我们签下了长谷川唯!在...
2022年的今天,我们签下了长谷川唯!在曼城的首个赛季,她就以出色的表 -
冠石科技:公司生产的功能性器件产品中...
冠石科技发布股票交易风险提示公告,公司的直接客户主要为京东方、富士