mybatis的缓存

1.mybatis的一级缓存

一级缓存是sqlSession级别的,即通过同一个sqlSession查询的数据会被缓存 再次使用同一个sqlSession查询同一条数据会从缓存中获取,一级缓存是默认开启的

一级缓存失效的四种情况:

1.不同的sqlSession对应不同的一级缓存

2.同一个sqlSession对应不同的查询语句

3.同一个sqlSession两次查询之间执行了任何一次增删改操作

4.同一个sqlSession两次查询期间手动清空了缓存(sqlSession.clearCache())

2.mybatis的二级缓存

二级缓存是sqlsessionFactory级别的,即通过同一个sqlsessionFactory所获取的sqlsession对象查询的数据会被缓存,再通过同一个sqlsessionFactory所获取的sqlsession查询的数据会从缓存中获取

Mybatis二级缓存开启的条件:

a>在核心配置文件中,设置全局配置属性cacheEnabled="true",默认为true,不需要设置

b>在映射文件中设置cache标签

c>二级缓存必须在SqlSession关闭或提交之后有效

d>查询的数据所转换的实体类类型必须实现序列化的接口

使二级缓存失效的情况:

两次查询之间执行了任意的增删改,会使一级和二级缓存同时失效

3.mybatis查询顺序:

先查询二级缓存,因为二级缓存中可能会有其他程序已经查出来的数据,可以拿来直接使用。

如果二级缓存没有命中,再查询一级缓存

如果一级缓存也没有命中,则查询数据库

SqlSession关闭之后,一级缓存中的数据会写入二级缓存


本文章使用limfx的vscode插件快速发布