mybatis-plus 缓存

龙永福
2023-12-01

mybatis提供缓存是为了减少与数据库的交互,有一级缓存和二级缓存。可提高查询效率。

一级缓存

  • 一级缓存也叫做本地缓存,是sqlsession层面的,作用范围只能在同一个sqlsession中。

  • 一级缓存是默认开启的,但要开启事物,因为每个事物都会创建新的sqlsession

  • 缓存失效:

  • 没有开启事务

  • sqlsession不同

  • 同一个 SqlSession 查询条件不同 也会不走缓存。

  • 手动清空缓存,调用SqlSession clearCache()方法

  • 什么时候清楚缓存:

  • 当执行增删改方法时

  • MyBatis全局配置属性localCacheScope配置为Statement时,那么完成一次查询就会清除缓存。

  • 是否配置了flushCache=true属性,如果配置了则会清除一级缓存。

二级缓存

  • Mybatis 二级缓存是mapper级别的,需要手动开启,作用范围更广,是mapper文件的一个命名空间

  • 开启二级缓存:需要手动开启

  • 缓存清除:执行增删改

  • 区别:

  • 一级缓存是SqlSession级别的缓存。在数据库操作时需要构建sqlSession对象,在对象中有一个数据结构(HashMap)用于存储缓存数据。不同的sqlSession之间的缓存数据区域(HashMap)之间是互不影响的。一级缓存默认开启不用配置。

  • 二级缓存是mapper级别的缓存,多个SqlSession去操作同一个Mapper的sql语句,多个SqlSession可以共用二级缓存,二级缓存是跨SqlSession的。二级缓存的开启(实体类必须序列化),然后在配置文件里面配置。

 类似资料: