MyBatis的内置缓存:MyBatis有一级缓存(SqlSession级别的缓存)和二级缓存(Mapper级别的缓存)

MyBatis的内置缓存包括一级缓存和二级缓存,它们的作用域具体描述如下:

一级缓存(SqlSession级别的缓存)

作用域

  • Session级别:一级缓存是与SqlSession关联的缓存。每个SqlSession都有自己的一级缓存。
  • 默认开启:MyBatis默认开启一级缓存,且无法关闭。
  • 作用域范围:同一个SqlSession内,执行相同的SQL语句(包括相同的SQL语句和参数)会返回缓存的结果,不会再次访问数据库。

特点

  • 生命周期:一级缓存的生命周期与SqlSession的生命周期相同。当SqlSession关闭或清除缓存时,一级缓存会被清空。SqlSession 的生命周期通常是一个方法或一个事务的执行时间。
  • 作用范围:一级缓存的范围有SESSION和STATEMENT两种,但默认是SESSION。如果不想使用一级缓存,可以将一级缓存的范围指定为STATEMENT,这样每次执行完一个Mapper中的语句后都会将一级缓存清除。

二级缓存(Mapper级别的缓存)

作用域

  • Mapper级别:二级缓存是跨SqlSession的缓存,作用于Mapper级别的数据缓存。
  • 默认关闭:MyBatis默认没有开启二级缓存,需要在全局配置(mybatis-config.xml)中开启二级缓存,并在具体的Mapper
    XML文件中进行配置。

特点

  • 作用域范围:同一个namespace下的mapper映射文件内容可以被多个SqlSession共享。即在不同的SqlSession中,相同的namespace下,相同的SQL语句(且SQL模板中参数也相同)会命中二级缓存。
  • 生命周期:二级缓存的生命周期比一级缓存长,可以被多个SqlSession共享。它的生命周期与Mapper的命名空间级别相同。
  • 数据序列化:由于二级缓存需要跨SqlSession共享,因此被查询的JavaBean需要实现Serializable接口以支持序列化。

注意事项

  • 当使用二级缓存时,需要确保数据的一致性和脏读问题。因为多个SqlSession可能同时修改同一个数据,这可能导致缓存中的数据与数据库中的数据不一致。
  • 可以通过配置不同的缓存策略(如FIFO、LRU等)来优化二级缓存的性能。

总结

MyBatis的一级缓存和二级缓存分别在不同的级别上提高了查询性能。一级缓存关注单个SqlSession的性能提升,而二级缓存则关注多个SqlSession之间的性能优化。在使用时,需要根据实际业务需求和数据访问模式来选择合适的缓存策略。

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值