Mybatis 中一级缓存与二级缓存

一级缓存: 基于 PerpetualCache HashMap 本地缓存,其存储作用域为 Session,当

Session flush close 之后,该 Session 中的所有 Cache 就将清空。
二级缓存与一级缓存其机制相同,默认也是采用 PerpetualCache HashMap 存储,不
同在于其存储作用域为 Mapper(Namespace) ,并且可自定义存储源,如 Ehcache 。作用域为
namespance 是指对该 namespance 对应的配置文件中所有的 select 操作结果都缓存,这样
不同线程之间就可以共用二级缓存。启动二级缓存:在 mapper 配置文件中: <cache />
二级缓存可以设置返回的缓存对象策略: <cache readOnly="true"> 。当 readOnly="true"
时,表示二级缓存返回给所有调用者同一个缓存对象实例,调用者可以 update 获取的缓存
实例,但是这样可能会造成其他调用者出现数据不一致的情况(因为所有调用者调用的是同
 
一个实例)。当 readOnly="false" 时,返回给调用者的是二级缓存总缓存对象的拷贝,即不
同调用者获取的是缓存对象不同的实例,这样调用者对各自的缓存对象的修改不会影响到其
他的调用者,即是安全的,所以默认是 readOnly="false";
对于缓存数据更新机制,当某一个作用域 ( 一级缓存 Session/ 二级缓存 Namespaces) 的进
行了 C/U/D 操作后,默认该作用域下所有 select 中的缓存将被 clear
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值