Mybatis框架--Mybatis的二级缓存机制

Mybatis 的二级缓存机制

什么是缓存
  • 缓存其实就是存储在内存中的临时数据,这里的数据量会比较小,一般来说,服务器的内存也是有限的,不可能将所有的数据都放到服务器的内存里面,所以, 只会把关键数据放到缓存中,缓存因为速度快,使用方便而出名!Mybatis作为一款优秀的ORM框架,自然也提供了缓存机制。
二级缓存机制
介绍
  • Mybatis设计了二级缓存来提高查询效率,避免每次都去直接查询数据库。
  • 一级缓存,它是 SqlSession 级别的缓存,也叫本地缓存,因为每个用户在执行查询的时候都需要使用 SqlSession 来执行,为了避免每次都去查数据库,MyBatis 把查询出来的数据保存到 SqlSession 的本地缓存中,后续的 SQL 如果命中缓存,就可以直接从本地缓存读取。
  • 想要实现跨 SqlSession 级别的缓存,一级缓存就无法实现了,因此,MyBatis引入了二级缓存。当多个用户在查询数据的时候,只要有任何一个 SqlSession 拿到了数据就会放入到二级缓存里面,其他的 SqlSession 就可以从二级缓存加载数据。
  • Mybatis读取缓存的顺序:先读取二级缓存再读取一级缓存。
原理

原理

一级缓存的实现原理:
  • 在 SqlSession 里面持有一个 Executor 的对象,每个 Executor 中有一个 LocalCache 对象。当用户发起查询的时候,MyBatis 会根据执行语句在 Local Cache 里面查询,如果没命中,再去查询数据库并写入到 LocalCache,否则直接返回。 一级缓存的生命周期为sqlSession。
二级缓存的实现原理:
  • 二级缓存使用了一个叫做 CachingExecutor 的对象,对 Executor 进行了装饰,在进入一级缓存的查询流程之前,会先通过 CachingExecutor 进行二级缓存的查询。开启二级缓存以后,会被多个 SqlSession 共享,所以它是一个全局缓存。因此它的查询流程是先查二级缓存,再查一级缓存,最后再查数据库。
  • 二级缓存相对于一级缓存来说,它实现了sqlsession之间的缓存数据的共享,同时缓存粒度也能控制到namespace的一个级别,并且还可以通过Cache的接口来实现不同缓存实现类的组合,对Cache的可控性也更高了。
  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

芝麻馅_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值