springboot下的mybatis缓存

一级缓存(默认开启)

sqlsession级别,对于同一session中多次一模一样的查询语句只会查询一次,但由于每次查询结束后都会sqlsession都会自动关闭,
一般情况下一级缓存并不会生效,需要开启事务@Transaction保证查询语句都在同一个回话才会生效。
一级缓存是本地或者说局部缓存,它不能被关闭,只能配置缓存范围。SESSION 或者 STATEMENT ,设置为statement 级别相当于关闭

mybatis:
  configuration:
    local-cache-scope: statement

二级缓存(默认关闭)

namespace级别
开启二级缓存,在mapper.xml文件添加,并且实体类需要实现序列化接口

 <cache/>

对于同一个namespace下的查询语句进行缓存,是跨session级别的,
例如session1先查询了sql1,session2也查询sql1,此时就会走缓存

总结:
一级二级缓存都开启的情况下执行顺序 二级缓存->一级缓存->数据库
进行增删改会清除缓存(同一作用域的缓存)
一级缓存容易产生脏数据,因为一级缓存是sqlsession级别的,无法感知到其他sqlsession的增删改,
例如session2对一条数据进行了修改,session1的一级缓存并不会清除,查询到的仍然是旧数据,建议设置为statment,
参考:SpringBoot 下 Mybatis 的缓存

你可能感兴趣的:(mybatis,spring,boot,缓存)