Mybatis缓存:
一级缓存是一直开启的,是SqlSession级别的一个map
失效条件:
- 1.SqlSession不同
- 2.SqlSession相同,查询条件不同
- 3.SqlSession相同,两次查询之间执行了增删改操作
- 4.SqlSession相同,手动清除了一级缓存
一级缓存失效,就需要再向数据库发查询语句
只有会话提交或关闭后,一级缓存中的数据才会转移到二级缓存中
二级缓存(全局缓存),是namespace(mapper)级别的,一个namespace对应一个二级缓存
工作机制:
- 1.一个会话,查询一条数据,这个数据就会被放在当前会话的一级缓存中
- 2.如果会话关闭,一级缓存中的数据会被保存到二级缓存中,新的会话查询数据,就可以参照二级缓存中的内容
- 3.如果一个sqlsession中保存了EmployeeMapper—>Employee对象和DepartmentMapper—>Department对象,这两个对象会被放入不同的map中,不同namespace查出的数据会放在自己对于的缓存(map)中
使用:
- 1.开启全局二级缓存配置
<setting name="cacheEnabled" value="true"/>
- 2.在mapper.xml中配置cache标签使用二级缓存
- 3.POJO需要实现序列化接口
cache标签的属性:
- eviction:缓存的回收策略,LRU,FIFO,SOFT,WEAK
- flushInterval:缓存刷新间隔(ms),默认不请空
- readOnly:是否只读,true或false
1)只读:mybatis认为所有从缓存中获取数据的操作都是只读操作,不会修改数据,mybatis为了加快获取速度,直接就将数据在缓存中的引用交给用户,不安全但速度快
2)非只读:mybatis觉得获取的数据可能会被修改,mybatis会利用序列化&反序列化的技术克隆一份新的数据给你,安全但速度慢 - size:缓存存放多少元素
- type:指定自定义缓存的全类名,实现cache接口即可
和缓存有关的设置/属性
1.cacheEnabled=true/false 一级缓存一直开启,可以对二级缓存进行设置
2.每个select标签都有useCache=true/false,false:不使用二级缓存,一级缓存仍然使用
3.每个增删改标签的flushCache=true,增删改执行完后就会清楚缓存(一级、二级)
4.SqlSession.clearCache() 只清除当前session的一级缓存