面试官:虫虫你简历上写了了解mybatis缓存,那你能说说一级缓存和二级缓存的区别吗?面试
虫虫:我只知道这是用来缓存sql查询的数据sql
面试官:没了?数据库
虫虫:没了缓存
面试官:公司门知道在哪里吧 本身走仍是我送你session
以上是虫虫的面试经历 因而虫虫决定恶补一下Mybatis缓存机制的知识mybatis
Mybatis对缓存提供支持,一级缓存是默认使用的app
二级缓存须要手动开启性能
区别:一级缓存的做用域是一个sqlsession内;二级缓存做用域是针对mapper进行缓存.
测试
在参数和SQL彻底同样的状况下,咱们使用同一个SqlSession对象调用一个Mapper方法,每每只执行一次SQL,由于使用SelSession第一次查询后,MyBatis会将其放在缓存中,之后再查询的时候,若是没有声明须要刷新,而且缓存没有超时的状况下,SqlSession都会取出当前缓存的数据,而不会再次发送SQL到数据库。spa
一级缓存时执行commit,close,增删改等操做,就会清空当前的一级缓存;当对SqlSession执行更新操做(update、delete、insert)后并执行commit时,不只清空其自身的一级缓存(执行更新操做的效果),也清空二级缓存(执行commit()的效果)。
二级缓存指的就是同一个namespace下的mapper,二级缓存中,也有一个map结构,这个区域就是一级缓存区域。一级缓存中的key是由sql语句、条件、statement等信息组成一个惟一值。一级缓存中的value,就是查询出的结果对象。
一、在配置文件中 开启二级缓存的总开关
<setting name="cacheEnabled" value="true" />
二、 在mapper映射文件中开启二级缓存
<cache eviction="FIFO" flushInterval="60000" size="512" readOnly="true"/>
参数名 | 属性 |
---|---|
eviction | 收回策略 |
flushInterval | 刷新间隔 |
size | 引用数目 |
readOnly | 只读 |
参数名 | 属性 |
---|---|
eviction="LRU" | 最近最少使用的:移除最长时间不被使用的对象。 (默认) |
eviction="FIFO" | 先进先出:按对象进入缓存的顺序来移除它们。 |
eviction="SOFT" | 软引用:移除基于垃圾回收器状态和软引用规则的对象。 |
eviction="WEAK" | 弱引用:更积极地移除基于垃圾收集器状态和弱引用规则的对象。 |
三、实体类实现Serializable
如测试sql语句性能时缓存会影响测试准确性 须要禁用
在映射文件中:
默认值是true useCache=”false”
<select id="findAllPets" resultMap="petsMap" useCache="false"> select * from pets </select>
在映射文件中:
属性:flushCache=”true”
刷新缓存,在查询
语句中,默认值是false
,在新增删除修改
语句中,默认值是true
(清空缓存)
要是能为您提供帮助,请给予支持(关注、点赞
、分享),虫虫蟹蟹你们了!