myabtis的缓存级别

简介: myabtis的缓存级别

文章目录

MyBatis缓存的区别是什么

作用范围方面有哪些差异

生命周期

数据进行了存储

缓存的优缺点

MyBatis缓存的区别是什么

MyBatis 提供了一级缓存和二级缓存,这两者的主要区别在于其作用范围和生命周期。


  1. 一级缓存:一级缓存是 SqlSession 级别的缓存。当我们执行查询时,它就会将查询结果缓存起来。当我们再次查询相同的数据,它就会直接从缓存中拉取。一级缓存是默认开启的。一级缓存的生命周期和 SqlSession 保持一致,当 SqlSession 被关闭或者清空,那么一级缓存就会消失
  2. 二级缓存:二级缓存是命名空间级别的缓存。一个命名空间可以理解为一个 Mapper 文件,即一个 XML 文件。不同的 Mapper 文件可以有不同的命名空间,即使它们都在同一个项目中。二级缓存是可以被多个 SqlSession 共享的。它的生命周期和应用程序保持一致,即应用程序运行期间,二级缓存一直存在。当应用程序关闭后,二级缓存才会消失

注意:使用二级缓存时,需要注意其适用场景。如果数据更新非常频繁,那么使用二级缓存可能不太合适,因为数据即使被更新,缓存中的数据也不会被立即清除,而是等待应用程序关闭后才会消失。这可能会导致数据不一致的问题。


作用范围方面有哪些差异

MyBatis的一级缓存和二级缓存的作用范围有明显的差异。


  1. 一级缓存是SqlSession级别的缓存,它的作用范围仅限于当前的SqlSession。也就是说,只有同一个SqlSession在执行两次相同的sql时,第一次得到的数据才会被缓存起来,第二次执行时直接从缓存中获取,提高效率。
  2. 而二级缓存是基于mapper的namespace作用域,但多个SqlSession操作同一个namespace下的sql时,只要传入的参数相同,执行相同的sql语句,第一次执行完毕后,会自动将sql提交并将数据缓存起来。也就是说,二级缓存在多个SqlSession之间共享数据,作用范围更广。
  3. 以上内容仅供参考,以MyBatis官方文档为准确 。

生命周期

MyBatis的缓存生命周期主要涉及到一级缓存和二级缓存。


  1. 一级缓存的生命周期和SqlSession保持一致。当开启一个新的数据库会话时,MyBatis会创建一个新的SqlSession对象,其中包含一个用于保存缓存数据的hashMap(以对象的id作为key,对象作为value保存)。当SqlSession执行DML(insert,update,delete)操作并提交到数据库时,MyBatis会清空SqlSession的一级缓存,以保存最新的数据并避免脏读现象。如果SqlSession调用close()方法或者clearCache()方法,一级缓存中的数据会被释放或者清空。
  2. 二级缓存的生命周期和应用程序保持一致,即应用程序运行期间,二级缓存一直存在。二级缓存是mapper级别的缓存,使用二级缓存时,多个SqlSession使用同一个mapper的sql语句去操作数据库,得到的数据存在二级缓存区域。二级缓存的范围更大,多个SqlSession可以共用二级缓存

以MyBatis官方文档为准确


数据进行了存储

MyBatis的一级缓存和二级缓存存储的数据主要是查询结果的对象。


  • 具体来说,一级缓存存储的是单个SqlSession中查询的数据,当同一个SqlSession再次查询相同的数据时,可以直接从缓存中获取,避免了重复的数据库查询操作,提高了效率。
  • 而二级缓存存储的是多个SqlSession之间共享的数据,当多个SqlSession查询相同的namespace下的数据时,只要传入的参数相同,执行相同的sql语句,第一次执行完毕后,会自动将sql提交并将数据缓存起来,供其他SqlSession使用,避免了重复的数据库查询操作,提高了效率。
  • 需要注意的是,MyBatis的二级缓存只会缓存查询语句,而不会缓存更新、插入、删除等语句。同时,MyBatis的二级缓存是将查询结果对象序列化后存储在硬盘上,读取时需要进行反序列化操作,因此在选择二级缓存时需要考虑到序列化和反序列化的开销。

缓存的优缺点

MyBatis 的一级缓存和二级缓存都有其优缺点


  • 优点

一级缓存

减少读数据库的读操作,降低数据库压力,加快响应速度

二级缓存

实现了缓存数据的共享,可控性也更强

  • 缺点

一级缓存

可能造成数据不一致问题

增加成本

二级缓存

极大可能会出现错误数据

安全使用的条件比较苛刻


MyBatis 的一级缓存和二级缓存都有其各自的优缺点。在选择使用缓存时,需要根据具体的应用场景和需求权衡这些优缺点,以做出最佳的选择。


相关文章
|
8月前
|
存储 缓存 分布式计算
亿级数据如何分钟级别写入缓存?
亿级数据如何分钟级别写入缓存?
65 0
|
2月前
|
存储 缓存 监控
多级缓存有哪些级别?
【10月更文挑战第24天】多级缓存有哪些级别?
50 1
|
7月前
|
存储 缓存 NoSQL
缓存分区及其透明性的处理方式
【6月更文挑战第8天】该文探讨了Redis缓存分区的重要性与方法。分区通过在多台服务器上分散缓存,提升可用性、性能和可伸缩性。最后,强调技术的双刃剑特性,需根据实际情况谨慎选用。
111 5
缓存分区及其透明性的处理方式
|
8月前
|
缓存 算法 NoSQL
中间件Cache-Aside策略命中缓存
【5月更文挑战第10天】中间件Cache-Aside策略命中缓存
95 8
|
8月前
|
存储 缓存 监控
中间件Cache-Aside策略缓存未命中
【5月更文挑战第10天】
89 7
|
8月前
|
存储 缓存 监控
|
8月前
|
消息中间件 缓存 监控
中间件如果缓存中存在所需的数据(缓存命中)
【5月更文挑战第12天】中间件如果缓存中存在所需的数据(缓存命中)
78 3
|
8月前
|
缓存 监控 中间件
中间件Cache-Aside策略缓存失效
【5月更文挑战第9天】中间件Cache-Aside策略缓存失效
87 5
|
8月前
|
存储 缓存 监控
中间件Cache-Aside策略检查缓存
【5月更文挑战第10天】中间件Cache-Aside策略检查缓存
85 5