Mybatis缓存

本文介绍了MyBatis的一级缓存与二级缓存。一级缓存默认开启,作用于SqlSession,不同Sqlsession不共享。二级缓存需要配置,可以在多个Sqlsession间共享,但需要注意在增删改操作后及时清理,以保持数据一致性。缓存命中率取决于业务场景,复杂的查询条件可能导致命中率降低。
摘要由CSDN通过智能技术生成

一级缓存:

默认开启,作用域是SqlSession,不同的Sqlsession的缓存是不共享的。

二级缓存:

需要配置,作用域是mapper,多个Sqlsession之间是可以共享的。

二级缓存的使用需要注意insert、update、delete操作清空缓存,否则真实的数据与缓存数据将不一致;另外关于缓存的命中率问题,相同查询条件在实际业务场景中多次出现的几率不高,也就是说缓存的命中率是开发前需要准确评估的。缓存中的key由sql语句、条件等信息组成,一般业务查询中会存在查询条件,而越多的查询条件,查询条件的值发生变化的可能就越高,往往带来的结果就是缓存 命中率越低。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值