Mybatis 踩坑第六弹—缓存

本文详细介绍了Mybatis的一级缓存和二级缓存机制。一级缓存默认开启,存在于Session级别,而二级缓存默认开启但需配置,基于namespace。文章列举了一级缓存失效的四种情况,并说明了二级缓存的工作流程、配置方法及注意事项。同时,讨论了增删改操作对缓存的影响,以及如何进行第三方缓存的整合。

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

Mybatis 支持两级缓存,分别是一级缓存(session 级别,又称本地缓存)和二级缓存(namespace 级别,又称全局缓存);

 

其中一级缓存默认开启,在于数据库相同的会话期间查询到的数据会放在本地缓存,之后再查询相同的数据会直接从本地缓存中取;但在四种情况下,一级缓存会失效:

1、使用不同的会话请求相同的数据;

2、使用相同的会话,请求不同的数据;

3、使用相同的会话,在请求之间执行了增删改操作,不论该操作是否针对一级缓存中的数据;

4、使用相同的会话,在请求之间主动清楚了一级缓存(session.clearCache());

 

二级缓存默认开启(但未配置),工作机制为:当使用 session 查询完数据之后将数据先保存在一级缓存中,在 session 关闭时,将一级缓存的数据取出并放进与之对应的 map 中,不同的 namespace 之间不共享 map;使用流程:

1)开启全局缓存配置;

2)在 mapper.xml 文件中配置使用二级缓存(因为二级缓存是基于 namespace 的,每个 mapper.xml 文件对应一个 namespace)

3)对应的 POJO 或者 PO 必须实现序列化接口(因为当 readOnly=false 时,缓存在返回数据的时候会使用到序列化的技术)

 

注意事项:

1)对于首次查询到的数据,默认都是放在一级缓存中的,只有当 session 提交或者关闭之后,数据才会转移到二级缓存中,也就是说在 session 提交或者关闭之前,二级缓存中是没有相关数据的;

2)cache 标签中中的 cacheEnabled=false 只会关闭二级缓存,而不会关闭一级缓存;select 标签中的 useCache=false 也只会关闭二级缓存,优先级高于 cache 标签;

3)对于每一个增删改标签中都有 flushCache 属性,当 flushCache=true时,每次执行完增删改之后会同时清空一级缓存和二级缓存;对于查询标签,默认 flushCache=false,当 flushCache=true 时,每个查询操作执行完,都会清空一级缓存和二级缓存;

4)session.clearCache 只会清空一级缓存;

5)localCacheScope 全局设置可以配置一级缓存的作用域,默认值为 session(使用一级缓存),当设定值为 statement 时,相当于禁用一级缓存;

 

第三方缓存整合:

1)导入第三方缓存的 jar 包;

2)导入 Mybatis 与第三方缓存的适配包(GitHub 上的 Mybatis 顶级项目下);

3)在 mapper.xml 中使用 cache 标签,通过 type 属性指定适配包接口的全类名。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值