前言
看Mybatis视频的总结,视频地址
Mybatis缓存
Mybatis缓存分为一级缓存和二级缓存
一级缓存
- 一级缓存默认开启且无法关闭
- 一级缓存生命周期是一个SQLSession,当SQLSession被关闭时,缓存消失(如果开启二级缓存,则缓存会被保存进二级缓存)
- 不同的Mapper有各自独立的缓存
- 在SQLSession开启期间,查询同一个id的对象会直接返回缓存中的对象,所以如果使用“==”来判断对象是否相等会得到true:
- 缓存失效(刷新)的情况:
- 增删改操作可能会改变原来的数据,所以会导致缓存失效
- 手动清理缓存:sqlSession.clearCache();
二级缓存
- 二级缓存全局是默认开启的,但是要使用需要在Mapper中手动开启:
Mapper中相关设置:
解释:
mybatis-config中的配置(默认是开启的):
- 基于namespace级别的缓存,一个名称空间对应一个二级缓存
- 如果要用二级缓存,实体类要实现序列化
工作机制:- 一个会话查询一条数据,这个数据就会被放在当前会话中的一级缓存中
- 如果当前会话关闭了,这个会话对应的一级缓存就没了;一级缓存中的数据会被保存到二级缓存中
- 新的会话查询信息,就可以从二级缓存中获取内容
- 不同的mapper查出的数据会放在自己对应的缓存(map)中
原理
Tips:
- 二级缓存是序列化存储的,所以查询同一个id的对象即使是走了缓存,使用“==”进行判断的结果是false(hash值不同),这是因为反序列化会得到一个新的对象
- 调优:只有select标签中可以选择是否使用缓存,而update等其他标签可以选择是否刷新缓存
- 一级缓存面向sqlSession,二级缓存面向mapper