共计 1329 个字符,预计需要花费 4 分钟才能阅读完成。
前言
面试官: 虫虫你简历上写了理解 mybatis 缓存,那你能说说一级缓存和二级缓存的区别吗?
虫虫: 我只晓得这是用来缓存 sql 查问的数据
面试官: 没了?
虫虫: 没了
面试官: 公司门晓得在哪里吧 本人走还是我送你
以上是虫虫的面试经验 于是虫虫决定恶补一下 Mybatis 缓存机制的常识
Mybatis 的缓存,包含一级缓存和二级缓存
Mybatis 对缓存提供反对,一级缓存是默认应用的
二级缓存须要手动开启
区别:一级缓存的作用域是一个 sqlsession 内;二级缓存作用域是针对 mapper 进行缓存.
一级缓存:
在参数和 SQL 齐全一样的状况下,咱们应用同一个 SqlSession 对象调用一个 Mapper 办法,往往只执行一次 SQL,因为应用 SelSession 第一次查问后,MyBatis 会将其放在缓存中,当前再查问的时候,如果没有申明须要刷新,并且缓存没有超时的状况下,SqlSession 都会取出以后缓存的数据,而不会再次发送 SQL 到数据库。
一级缓存时执行 commit,close,增删改等操作,就会清空以后的一级缓存;当对 SqlSession 执行更新操作(update、delete、insert)后并执行 commit 时,不仅清空其本身的一级缓存(执行更新操作的成果),也清空二级缓存(执行 commit()的成果)。
二级缓存:
二级缓存指的就是同一个 namespace 下的 mapper,二级缓存中,也有一个 map 构造,这个区域就是一级缓存区域。一级缓存中的 key 是由 sql 语句、条件、statement 等信息组成一个惟一值。一级缓存中的 value,就是查问出的后果对象。
1、在配置文件中 开启二级缓存的总开关
<setting name="cacheEnabled" value="true" />
2、在 mapper 映射文件中开启二级缓存
<cache eviction="FIFO" flushInterval="60000" size="512"
readOnly="true"/>
参数名 | 属性 |
---|---|
eviction | 发出策略 |
flushInterval | 刷新距离 |
size | 援用数目 |
readOnly | 只读 |
对于 eviction 的各个参数属性:
参数名 | 属性 |
---|---|
eviction=”LRU” | 最近起码应用的: 移除最长工夫不被应用的对象。(默认) |
eviction=”FIFO” | 先进先出: 按对象进入缓存的程序来移除它们。 |
eviction=”SOFT” | 软援用: 移除基于垃圾回收器状态和软援用规定的对象。 |
eviction=”WEAK” | 弱援用: 更踊跃地移除基于垃圾收集器状态和弱援用规定的对象。 |
3、实体类实现 Serializable
禁用缓存
如测试 sql 语句性能时缓存会影响测试准确性 须要禁用
在映射文件中:
默认值是 true useCache=”false”
<select id="findAllPets" resultMap="petsMap" useCache="false">
select * from pets
</select>
刷新缓存
在映射文件中:
属性:flushCache=”true”
刷新缓存,在查问语句中,默认值是 false,在新增删除批改语句中,默认值是 true(清空缓存)
要是能为您提供帮忙,请给予反对(关注、点赞、分享),虫虫蟹蟹大家了!