Mybatis 踩坑第六弹—缓存

Posted Javall咖啡屋

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mybatis 踩坑第六弹—缓存相关的知识,希望对你有一定的参考价值。

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 属性指定适配包接口的全类名。

以上是关于Mybatis 踩坑第六弹—缓存的主要内容,如果未能解决你的问题,请参考以下文章

Mybatis-Plus自动填充功能 - 踩坑

前端学习 第六弹: javascript中的函数与闭包

MyBatis踩坑之SQLProvider转义字符被删除问题

Mybatis-Plus自动填充功能 - 踩坑

Mybatis-Plus自动填充功能 - 踩坑

Mybatis-Plus自动填充功能 - 踩坑