深入理解Mybatis二级缓存
上篇文章给大家介绍了mybatis一级缓存,有需要的朋友可以参考下。
与一级缓存相比,二级缓存范围更大了一些,可以被多个SqlSession所共用。
同样是发送同样的查询sql会先去缓存中找,找不到再去查询数据库。
每个namespace的mapper都会有自己的一个缓存的空间。
如果两个mapper的namespace相同,执行mapper查询到的数据将存储到相同的二级缓存.
同样如果有sqlSession执行了commit 会清空二级缓存.
配置文件(不用配置也是默认开启的):
在sqlMapConfig.xml中:
<setting name="cacheEnabled" value="true"/>
在相应的mapper.xml中:
<cache/>
如果不需要二级缓存,可以在设置禁用二级缓存
<select useCache="false"></select>
这样每次都是从数据库中读取
在执行insert,update,delete后会刷新缓存(清空缓存),可以设置不刷新
一般不予设置,设置可能会导致脏读.
<insert flushCache="false"></insert>
小例子:
SqlSession session1 = factory.openSession();
SqlSession session2 = factory.openSession();
SqlSession session3 = factory.openSession();
UserMapper mapper1 = session1.getMapper(UserMapper.class);
UserMapper mapper2 = session2.getMapper(UserMapper.class);
UserMapper mapper3 = session3.getMapper(UserMapper.class);
//第一次请求,查询id为1的用户
User user1 = mapper1.findUserById(1);
System.out.println(user1);
//close 将数据写入二级缓存
session1.close();
//清空二级缓存,UserMapper下的
user1.setUsername("mmm");
mapper3.updateUser(user1);
session3.commit();
//第二次查询会从缓存中找
User user2 = mapper2.findUserById(1);
System.out.println(user2);
session2.close();
注意此处要进行二级缓存的对象必须实现Serilizable接口,因为这些缓存数据可能会反序列化写到硬盘或者其他地方。
以上所述是小编给大家介绍的Mybatis二级缓存,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
相关文章
springboot从application.properties中注入list, map方式
这篇文章主要介绍了springboot从application.properties中注入list,map方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-11-11
ConcurrentHashMap是如何实现线程安全的你知道吗
这篇文章主要介绍了ConcurrentHashMap是如何实现线程安全的你知道吗,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-10-10
Spring Cloud Stream与Kafka集成步骤(项目实践)
Spring Cloud Stream是一个用于构建消息驱动微服务的框架,它是基于Spring Boot和Spring Integration创建的,旨在简化与消息中间件的集成工作,本教程介绍了如何结合Spring Cloud Stream框架和Apache Kafka消息代理,创建一个集成示例应用,感兴趣的朋友一起看看吧2025-08-08
Nacos+Spring Cloud Gateway动态路由配置实现步骤
Nacos最近项目一直在使用,本文通过gateway、nacos-consumer、nacos-provider三个简单模块来展示:Nacos下动态路由配置,,感兴趣的小伙伴们可以参考一下2021-08-08
Java 语言守护线程 Daemon Thread使用示例详解
这篇文章主要为大家介绍了Java 语言守护线程 Daemon Thread使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2022-10-10


最新评论