两级缓存:(缓存是一个map)
- 一级缓存(本地缓存):(sqlSession级别的缓存,是默认一直开启的)
- 与数据库一次会话查询到的数据会放在本地换存中,以后如果需要获取相同的数据,直接从缓存中取。
- 一级缓存失效情况:(没有使用到当前一级缓存的情况,即再次向数据库发送请求)
- sqlSession不同
- sqlSession相同:条件不同
- sqlSessiin相同:两次查询之间执行了增删改操作
- sqlSession相同:手动清除了一级缓存
- 二级缓存(全局缓存):(基于namespace级别的缓存:一个namespace对应一个二级缓存)
- 工作机制:
- 一次会话查询一条数据,默认保存到当前的一级缓存
- 如果会话关闭:一级缓存中的数据会被保存到二级缓存中:如果有新的会话会先查找二级缓存
- 不同namespace查出的数据会放在对应的缓存中(map)
- 使用:
- 开启二级缓存配置:<setting name=“chcheEnabled” value=“true”>(value=false关闭二级缓存,不会关闭一级缓存。)
- 去mapper.xml中配置使用二级缓存:<cache></cache>
- POJO需要实现序列化接口
- 每个select标签都有useCache=“true”:(false依然是关闭二级缓存,不会影响一级缓存)
- 每个增删改默认都有flushCache=“true”:执行增删改后会清空缓存(一级和二级都会被清空)。
- 查询标签的flushCache默认为false:如果为true,每次查询完毕就会清空缓存
- SqlSession.clearCache();只会清除一级缓存。
- localCacheScope:本地缓存作用域(一级缓存)STATEMENT可以禁用一级缓存
- 访问顺序:二级缓存->一级缓存->数据库
- MyBatis支持其他缓存框架如redis等:
1、导入第三方缓存包
2、导入与第三方整合的适配包
3、在mapper.xml中引用第三方缓存即可
4、通过<cache-ref namespace=""/>指定和哪个命名空间使用相同的缓存
文章目录
喜欢的话可以点点关注,或者添加作者微信,欢迎随时来撩
</div>
<link href="https://csdnimg.cn/release/phoenix/mdeditor/markdown_views-778f64ae39.css" rel="stylesheet">
</div>
两级缓存:(缓存是一个map)
- 一级缓存(本地缓存):(sqlSession级别的缓存,是默认一直开启的)
- 与数据库一次会话查询到的数据会放在本地换存中,以后如果需要获取相同的数据,直接从缓存中取。
- 一级缓存失效情况:(没有使用到当前一级缓存的情况,即再次向数据库发送请求)
- sqlSession不同
- sqlSession相同:条件不同
- sqlSessiin相同:两次查询之间执行了增删改操作
- sqlSession相同:手动清除了一级缓存
- 二级缓存(全局缓存):(基于namespace级别的缓存:一个namespace对应一个二级缓存)
- 工作机制:
- 一次会话查询一条数据,默认保存到当前的一级缓存
- 如果会话关闭:一级缓存中的数据会被保存到二级缓存中:如果有新的会话会先查找二级缓存
- 不同namespace查出的数据会放在对应的缓存中(map)
- 使用:
- 开启二级缓存配置:<setting name=“chcheEnabled” value=“true”>(value=false关闭二级缓存,不会关闭一级缓存。)
- 去mapper.xml中配置使用二级缓存:<cache></cache>
- POJO需要实现序列化接口
- 每个select标签都有useCache=“true”:(false依然是关闭二级缓存,不会影响一级缓存)
- 每个增删改默认都有flushCache=“true”:执行增删改后会清空缓存(一级和二级都会被清空)。
- 查询标签的flushCache默认为false:如果为true,每次查询完毕就会清空缓存
- SqlSession.clearCache();只会清除一级缓存。
- localCacheScope:本地缓存作用域(一级缓存)STATEMENT可以禁用一级缓存
- 访问顺序:二级缓存->一级缓存->数据库
- MyBatis支持其他缓存框架如redis等:
1、导入第三方缓存包
2、导入与第三方整合的适配包
3、在mapper.xml中引用第三方缓存即可
4、通过<cache-ref namespace=""/>指定和哪个命名空间使用相同的缓存
文章目录
喜欢的话可以点点关注,或者添加作者微信,欢迎随时来撩
</div>
<link href="https://csdnimg.cn/release/phoenix/mdeditor/markdown_views-778f64ae39.css" rel="stylesheet">
</div>