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的。二级缓存的开启(实体类必须序列化),然后在配置文件里面配置。