首页 > 其他 > 详细

Mybatis二级缓存问题

时间:2021-08-30 03:17:53      阅读:4      评论:0      收藏:0      [点我收藏+]

一、缓存介绍。

Mybatis提供了缓存服务,以减缓数据库压力;

Mybatis的查询缓存总共有两级,我们称之为一级缓存和二级缓存,如图: 

 技术分享图片

 

 

  1、一级缓存是SqlSession级别的缓存。在操作数据库时需要构造 sqlSession对象,在对象中有一个数据结构(HashMap)用于存储缓存数据。不同的sqlSession之间的缓存数据区域(HashMap)是互相不影响的。

 

  2、二级缓存是Mapper(namespace)级别的缓存。多个SqlSession去操作同一个Mapper的sql语句,多个SqlSession可以共用二级缓存,二级缓存是跨SqlSession的。

 

二、一级缓存

技术分享图片

 

 

三、二级缓存。

  技术分享图片

 

  二级缓存的颗粒度是Mapper级别;

  

四、二级缓存问题。

 

  问题:当查询student表与teacher联表查询,第一次查询出来并缓存到二级缓存中,现在更新teacher表,再次查询student表与teacher联表,调取二级缓存,发现刚才更新的数据并未更新;

 

  解决方法:当BMapper执行对BTable的update操作时,指定刷新 ACache中的 selectATableWithJoin语句产生的缓存;mybatis-enhanced-cache 插件就是解决这个问题的。

 

 

 

 

 

 

Mybatis二级缓存问题

原文:https://www.cnblogs.com/jiangbaoyabo/p/15193873.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!