一级缓存是sqlSession级别的,即通过同一个sqlSession查询的数据会被缓存 再次使用同一个sqlSession查询同一条数据会从缓存中获取,一级缓存是默认开启的
一级缓存失效的四种情况:
1.不同的sqlSession对应不同的一级缓存
2.同一个sqlSession对应不同的查询语句
3.同一个sqlSession两次查询之间执行了任何一次增删改操作
4.同一个sqlSession两次查询期间手动清空了缓存(sqlSession.clearCache())
二级缓存是sqlsessionFactory级别的,即通过同一个sqlsessionFactory所获取的sqlsession对象查询的数据会被缓存,再通过同一个sqlsessionFactory所获取的sqlsession查询的数据会从缓存中获取
Mybatis二级缓存开启的条件:
a>在核心配置文件中,设置全局配置属性cacheEnabled="true",默认为true,不需要设置
b>在映射文件中设置cache标签
c>二级缓存必须在SqlSession关闭或提交之后有效
d>查询的数据所转换的实体类类型必须实现序列化的接口
使二级缓存失效的情况:
两次查询之间执行了任意的增删改,会使一级和二级缓存同时失效
先查询二级缓存,因为二级缓存中可能会有其他程序已经查出来的数据,可以拿来直接使用。
如果二级缓存没有命中,再查询一级缓存
如果一级缓存也没有命中,则查询数据库
SqlSession关闭之后,一级缓存中的数据会写入二级缓存
本文章使用limfx的vscode插件快速发布