Mybatis缓存机制

MyBatis 中的缓存机制可以帮助提高数据库访问性能,减少不必要的数据库查询。MyBatis 默认提供了两级缓存:一级缓存和二级缓存。

  1. 一级缓存

    • 一级缓存是指 MyBatis 在同一个 SqlSession 中的缓存,它是 SqlSession 级别的缓存。
    • 当同一个 SqlSession 中执行相同的查询时,如果查询结果在缓存中存在,MyBatis 将直接从缓存中获取结果,而不会再次向数据库发送查询请求。
    • 一级缓存是 MyBatis 默认开启的,无法关闭,它可以有效地减少相同查询的重复执行次数。
  2. 二级缓存

    • 二级缓存是指 MyBatis 在多个 SqlSession 之间共享的缓存,它是 Mapper 级别的缓存。
    • 当不同的 SqlSession 执行相同的查询时,如果查询结果在缓存中存在,MyBatis 将直接从缓存中获取结果,而不会向数据库发送查询请求。
    • 二级缓存可以提高多个 SqlSession 之间的查询性能,减少数据库查询次数,但是它是可选的,需要手动配置和开启。

配置 MyBatis 的二级缓存需要在 Mapper.xml 文件中添加 <cache> 标签,并指定缓存的类型和其他相关属性。例如:

xml 复制代码
<cache type="org.mybatis.caches.ehcache.EhcacheCache"/>

以上配置了一个使用 Ehcache 作为二级缓存的示例。MyBatis 还支持其他类型的缓存,如 PerpetualCache、FifoCache、LRUCache 等,也支持自定义缓存实现。

需要注意的是,缓存的有效性是有限的,当数据库中的数据发生变化时,缓存中的数据也会失效。因此,在使用缓存时需要谨慎考虑缓存的策略和失效机制,以确保缓存的一致性和正确性。

相关推荐
工一木子3 小时前
URL时间戳参数深度解析:缓存破坏与前端优化的前世今生
前端·缓存
陌殇殇3 小时前
SpringBoot整合SpringCache缓存
spring boot·redis·缓存
一只叫煤球的猫8 小时前
手撕@Transactional!别再问事务为什么失效了!Spring-tx源码全面解析!
后端·spring·面试
喜欢敲代码的程序员9 小时前
SpringBoot+Mybatis+MySQL+Vue+ElementUI前后端分离版:项目搭建(一)
spring boot·mysql·elementui·vue·mybatis
赤橙红的黄9 小时前
自定义线程池-实现任务0丢失的处理策略
数据库·spring
数据狐(DataFox)10 小时前
SQL参数化查询:防注入与计划缓存的双重优势
数据库·sql·缓存
小时候的阳光10 小时前
SpringBoot3 spring.factories 自动配置功能不生效?
spring boot·spring·失效·factories·imports
大只鹅11 小时前
Springboot3整合ehcache3缓存--XML配置和编程式配置
spring boot·缓存
张小洛12 小时前
Spring IOC容器核心阶段解密:★Bean实例化全流程深度剖析★
java·后端·spring·ioc容器·bean实例化
持之以恒的天秤12 小时前
Redis—哨兵模式
redis·缓存