当前位置: 首页 > news >正文

MyBatis-Plus拦截器接口InnerInterceptor失效?因MyBatis缓存机制而踩的一个深坑

InnerInterceptor 接口是 MyBatis-Plus 提供的一个拦截器接口,用于实现一些常用的 SQL 处理逻辑。例如某个组件运作在多系统的平台上,不同系统需要隔离,于是可以通过这个拦截器接口,给每一条要执行的sql末尾拼接一个AND systemId = "?"的条件来实现不同系统只能查到对应系统ID的数据。

具体玩法样例可以参考这个文章:

Mybatis-Plus实现拦截器接口InnerInterceptor

而今天项目遇到的一个bug情景如下:
所有的sql原本都要通过拦截器拼接这个校验系统ID的条件,但其中一条sql因为要查整个数据库中的数据是否有重复,所以就要去掉这个拼接的条件进而查询整个库表。这里我们之前已经有代码可以实现了,简单来说就是在拦截器里加个if,只有在满足if条件后才去拼接条件sql。
然而复制了之前能跳过拦截器的方法去开发这次的新需求,却非常意外的没能生效,sql语句还是把校验systemId的条件给拼接进去了。打了断点也摸不着头脑,明明代码是一模一样的呀,接收到的参数也是满足跳过拦截条件的,为什么还是会被拦截了呢?

在这里插入图片描述

其实标题已经算剧透了,大伙心里应该都有数了吧?那就来详细说说找出问题的步骤:


先是把断点打到了selectOne前后,发现日志没打印sql,然而依然获取到了查询结果的对象,这是怎么一回事?

继而把断点打到拦截器里,发现在执行这条mybatis-plus的方法时根本就没进拦截器,断点没捕获到。

此时就有很多种猜测了,甚至还猜想过会不会和service层加了事务有关

不过最终的正解是由于mybatis的缓存机制,因为我在该方法里执行这条查询sql前已经执行过一遍相同的sql了(目的是先查询一遍加了systemId校验的,再查一遍全表的),所以mybatis的缓存机制生效,直接将已缓存的sql包括结果直接返回了,所以压根就没执行这条想查全表的sql,故而别说拦截器里的if是否判断了,就连进都没进来,这就是拦截器里断点没捕获到的原因。


解决方法:

1、配置文件中加上
# propertiesmybatis.configuration.local-cache-scope=statement
# yamlmybatis:configuration:local-cache-scope: statement

关闭mybatis的一级缓存

ps:金融行业不适合使用这个一级缓存,容易出现数据不一致,也没提升多少性能

2、在不能关闭一级缓存的情况下,重新写一条结果一样但内容不一样的sql

sql有差别就不会走缓存机制了。比如你之前的sql是用mybatis生成的,这里就直接用Mapper手写一条


THX!

http://www.lryc.cn/news/431517.html

相关文章:

  • jmeter之计数器
  • 协议集合(学习笔记)
  • 进程
  • 10款好用的电脑监控软件推荐丨2024年干货整理,赶紧码住!
  • 【MySQL-24】万字全面解析<索引>——【介绍&语法&性能分析&使用规则】
  • 刷题记录(2)
  • JVM中的GC过程
  • Python实战项目:天气数据爬取+数据可视化(完整代码)_python爬虫实战
  • FFmpeg源码:compute_frame_duration函数分析
  • ARM 异常处理(21)
  • 我开源了我的新闻网站项目
  • LlamaIndex 使用 RouterOutputAgentWorkflow
  • 设计模式学习-责任链模式
  • 【全网最全】2024年数学建模国赛B题31页完整建模过程+成品论文+matlab/python代码等(后续会更新
  • 第二十一届华为杯数学建模经验分享之资料分享篇
  • 使用 OpenSSL 创建自签名证书
  • EmguCV学习笔记 VB.Net 9.1 VideoCapture类
  • Rspack 1.0 发布了!
  • 【全网最全】2024年数学建模国赛E题超详细保奖思路+可视化图表+成品论文+matlab/python代码等(后续会更新
  • 数智转型,看JNPF如何成为企业的必备工具
  • ArcGIS Pro 发布松散型切片
  • 奖项再+1!通义灵码智能编码助手通过可信 AI 智能编码工具评估,获当前最高等级
  • 如何使用 yum 在 CentOS 6 上安装 nginx
  • F12抓包05:Network接口测试(抓包篡改请求)
  • OPenCV结构分析与形状描述符(4)计算一个旋转矩形的四个顶点的函数boxPoints()的使用
  • 【Matplotlib】利用Python进行绘图!(python数据分析与可视化)
  • 第二百二十节 JPA教程 - JPA 实体管理器删除示例
  • [⁠TypeError⁠]‍ {message: “Cannot read property ‘‘ of undefined“}
  • NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南001
  • 项目在运行时,浏览器控制台出现 Uncaught ReferenceError: globalThis is not defined