查询:连接数据库,消耗资源。
一次查询的结果,给他暂存在一个可以直接取到的地方。-->内存:缓存
我们再次查询相同数据的时候,直接走缓存,就不用走数据库。从而提高查询效率,解决了高并发系统的性能问题。
缓存:存在内存中的临时数据。
适用场景:经常查询并且不经常改变的数据。
Mybatis缓存:
Mybatis包含一个非常强大的查询缓存特性,他可以非常方便地制定和配置缓存,缓存可以极大地提高查询效率。
Mybatis系统中默认定义了两级缓存:一级缓存和二级缓存。
默认情况下,只有一级缓存开启,(sqlsession级别的缓存,也称为本地缓存)
二级缓存需要手动开启和配置,它是基于namesapce级别的缓存,
为了提高扩展性,Mybatis定义了缓存接口Cache,我们可以通过实现Cache接口来自定义二级缓存。
一级缓存:
测试步骤:
1.开启日志
2.测试在一个Session查询两次相同的记录
3.查看两次查询步骤日志:

缓存失效情况:
1.增上改查,可能会改变原来的数据,所以必定会刷新缓存
2.查询不同东西
3.查询不同Mapper.xml
4.手动清理缓存
二级缓存:
默认情况下,之启用了本地会话缓存,它仅仅对一个会话中的数据进行缓存,要启用全局的二级缓存,只需在SQL映射文件中添加配置。
步骤:开启全局缓存
cacheEnabled:全局的开启或关机配置文件中所有映射器已经配置的任何缓存。
1.mybatis-config.xml:
<setting name="cacheEnabled" value="true"/><!--开启二级缓存-->
2.Mapper.xml:
<!--在当前Mapper.xml中使用二级缓存-->
<cache eviction="FIFO" flushInterval="60000" readOnly="true" size="1024"/>
3.测试:

总结:
只要开启了二级缓存,在同一个Mapper下就有效,
所有的数据都会先放在一级缓存中;
只有当绘画提交,或者关闭的时候,才会提交到二级缓存中。
3万+

被折叠的 条评论
为什么被折叠?



