Mysbatis一级缓存和二级缓存

Mysbatis一级缓存

一级缓存是SqlSession级别的缓存,缓存对数据库的操作的结果,如果下一次用户再执行相同的请求,那么直接从内存中读取而不是从数据库读取。

一级缓存失效的情况:

1.只对当前SqlSession对象生效,对于其他的SqlSession来说不起作用

2.是当前SqlSession对象,但是执行的是不同条件的SQL查询语句。

3.同一个SqlSession对象执行同一条件的查询语句,但中间执行了增删改的操作,之前一级缓存中的数据会失效。如果执行的是不同条件的查询语句,一级缓存仍然生效,并且会把新的查询数据也加入到一级缓存中。

4.多次相同查询语句在执行期间通过sqlSession.clearCache();方法清除了缓存

5.SqlSession 对象调用了close()方法,当前会话结束,一级缓存不再生效。

 

Mysbatis级缓存

二级缓存就是全局缓存它超出session范围之外,可以被所有Session共享,需要注意的是全局缓存的作用域是针对Mapper的Namespace而言的,也就是说只在有在这个Namespace内的查询才能共享这个cache,但并不是意味着同一个namespace创建的mapper可以互相读取缓存内容,

 

保存顺序:每个SqlSession在执行查询操作的时候,都会将查询的结果放在当前会话的一级缓存中。如果当前会话关闭,一级缓存中的数据会被保存在二级缓存中。因此二级缓存是在一级缓存的基础上进行扩展的,不同的namespace查出的数据都会将数据存在自己对应的缓存中,这些缓存信息使用Map存储。

查询顺序:MyBatis 在开启二级缓存的情况下,如果发出了一条SQL 查询语句,会先向二级缓存中查询是否有对应的缓存数据,如果没有再接着查询一级缓存中的数据,如果一级缓存中也没有对应的缓存数据,才会向数据库发送SQL。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值