Mybatis系列2-一级缓存和二级缓存

本文介绍了MyBatis的一级缓存和二级缓存。一级缓存默认启用,存在于SqlSession生命周期,INSERT、UPDATE、DELETE操作会清空,可配置关闭。二级缓存存在于SqlSessionFactory生命周期,跨SqlSession,以namespace为单位,有全局开关,开启后有多种特性,但可能出现脏读问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.一级缓存

一级缓存默认会启用,存在于 SqlSession 的生命周期中,在同一个SqlSession 中查询时, MyBatis会把执行的方法和参数通过算法生成缓存的键值,将键值和查询结果存入一个Map对象中。如果同一个SqlSession 中执行的方法和参数完全一致,则会返回缓存中的对象。任何的 INSERT 、UPDATE 、 DELETE 操作都会清空一级缓存。可以通过在select标签上配置flushCache=“true”关闭一级缓存

2.二级缓存

二级缓存存在于SqlSessionFactory的生命周期中,跨sqlSession。缓存是以namespace为单位的,不同namespace下的操作互不影响。setting参数 cacheEnabled,这个参数是二级缓存的全局开关,如果设置为 false,即使有后面的二级缓存配置,也不会生效;
开启二级缓存:

<cache eviction="lru" flushInterval="60000" size="512" readOnly="true"/> 

效果如下:
映射语句文件中的所有 select 语句将会被缓存。
映射语句文件中的所有 insert,update 和 delete 语句会刷新缓存。
缓存会使用 Least Recently Used(LRU,最近最少使用的)算法来收回。
根据时间表(比如 no Flush Interval,没有刷新间隔), 缓存不会以任何时间顺序 来刷新。
缓存会存储列表集合或对象(无论查询方法返回什么)的 512个引用。
缓存会被视为是 read/write(可读/可写)的缓存
由于二级缓存是以namespace为单位,可能会出现脏读。比如在关联查询时候,有一个订单查询在namespaceA,查询订单的时候会关联查询订单详细,而还有一个查询、修改订单详细在namespaceB。这时候在查询订单时候,订单详细也缓存在namespaceA。这时候namespaceB中修改订单,但namespaceA中的订单详情不会变。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值