Mybatis-Plus更新操作时的一个坑

Mybatis-Plus更新操作时的一个坑

在 MyBatis-Plus开启逻辑删除 的情况下,updateById更新逻辑删除字段时, “看起来执行了但实际上没有更新”的问题是一种较为常见但不易察觉的问题。

背景:

项目中使用mybatis-plus且已开启逻辑删除:

1 mybatis-plus:

2 global-config:

3 db-config:

4 logic-delete-field: deleted

5 logic-delete-value: 1

6 logic-not-delete-value: 0

7 update-strategy: not_empty #更新策略只更新非空

在代码中获取记录并更新逻辑删除字段:

1 useRecord record = RecordMapper.selectOne(...);

2 record.setDeleted(1);

3 RecordMapper.updateById(record);

执行结果没有明显报错,也不会有异常日志,但实际没有更新逻辑删除字段。

如果没有记录执行返回值进行判断,将导致逻辑删除失败问题被隐藏,为后续业务埋雷。

原因分析:

mybatis-plus使用逻辑删除背景下,使用updateById时,如下代码段:

1 record.setDeleted(1);

2 RecordMapper.updateById(record);

执行的sql语句是:

1 UPDATE table_name

2 SET deleted = 1

3 WHERE id = ?

4 AND deleted = 0; -- ⚠️ MyBatis-Plus 自动添加的条件

这条 SQL 在语法层面是合法的,但在 MyBatis-Plus 的设计语义中,逻辑删除并不被视为一次普通的 update 操作。

MyBatis-Plus 将“删除”与“更新”在内部逻辑上进行了区分:updateById 被设计为只能作用于“未被逻辑删除的数据”,而逻辑删除本身应通过 delete 系列方法触发。

1 -- 你期望生成的SQL(框架不会生成)2 UPDATE record SET deleted = 1 WHERE id = ? AND deleted = 0;

3

4 -- updateById实际生成的SQL(deleted字段被剔除)5 UPDATE record SET other_field=? WHERE id = ? AND deleted = 0;

Mybatis-Plus为什么要这样设计:

MyBtis-Plus 遵循 "语义隔离" 原则

操作类型 框架方法 SQL语义 设计意图

业务更新 updateById() 修改业务字段 只改数据内容,不改数据状态

逻辑删除 deleteById() UPDATE ... SET deleted=1 标记数据为"已删除"状态

关键机制:

拦截器过滤:LogicDeleteInterceptor 会自动移除 SET 子句中的逻辑删除字段

条件追加:所有查询/更新操作都会自动追加 AND deleted = 0

单向操作:逻辑删除被视为不可逆操作(删除后不应通过业务代码恢复)

如何正确处理:

使用 MyBatis-Plus 提供的 deleteById 进行逻辑删除

1 // 框架会自动生成:UPDATE user SET deleted=1 WHERE id=? AND deleted=02 recordMapper.deleteById(1L);

在开启逻辑删除的前提下,deleteById 不会执行物理删除,而是由 MyBatis-Plus 自动生成逻辑删除 SQL,其语义与框架设计完全一致。

用 LambdaUpdateWrapper 显式执行逻辑删除

1 // 手动指定SET子句,绕过字段过滤

2 LambdaUpdateWrapper<Record> wrapper = new LambdaUpdateWrapper<>();

3 wrapper.eq(Record::getId, 1L).set(Record::getDeleted, 1); // 强制设置deleted字段

4 recordMapper.update(n

ull, wrapper);

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1173871.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Postman发送POST请求,模拟请求头界面的响应信息

&#x1f345; 点击文末小卡片&#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快postman发送POST请求示例&#xff1a;微信公众平台创建用户标签接口&#xff0c;业务操作如下&#xff1a;1、打开微信公众平台&#xff0c;微信扫码登录&#xff1…

Linux内核是怎么发现内存泄漏的?深入kmemleak源码,揭秘检测原理

用户态内存泄漏好查,有Valgrind、ASan这些神器。但内核态?那完全是另一回事。 内核模块一旦泄漏内存,不会像用户进程那样被OOM Killer干掉,而是一直占着内存,直到系统重启才能释放,更麻烦的是内核没有独立的地址空间隔离,一个驱动的泄漏可能把整个系统拖垮。 那Linux内…

Java实习模拟面试复盘:深度剖析高并发数据库设计、Redis去重与Agent系统架构(百度日常实习后端二面)

Java实习模拟面试复盘&#xff1a;深度剖析高并发数据库设计、Redis去重与Agent系统架构&#xff08;百度日常实习后端二面&#xff09;关键词&#xff1a;Java面试 | 数据库设计 | Redis | 分布式系统 | Agent架构 | 百度面试在参加百度日常实习后端开发岗位的第二轮技术面试中…

Java版LeetCode热题100之二叉树的中序遍历:从递归到Morris遍历的深度解析

Java版LeetCode热题100之二叉树的中序遍历&#xff1a;从递归到Morris遍历的深度解析 本文将全面、深入地剖析 LeetCode 第94题「二叉树的中序遍历」&#xff0c;不仅提供三种主流解法&#xff08;递归、迭代、Morris&#xff09;&#xff0c;还涵盖算法原理、复杂度分析、面试…

供电系统:TN系统、TT系统、IT系统

TN系统 对于TN方式供电系统而言&#xff0c;它主要指的是一种将电气设备的金属外壳与工作零线进行有效相接的保护系统&#xff0c;因此TN方式供电系统又被称作为接零保护系统。值得一提的是&#xff0c;在TN方式供电系统当中&#xff0c;又可以根据其保护零线是否与工作零线向…

Jmeter分布式压测详解

&#x1f345; 点击文末小卡片 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 一、什么是压力测试&#xff1f; 压力测试&#xff08;Stress Test&#xff09;&#xff0c;也称为强度测试、负载测试&#xff0c;属于性能测试的范畴。 压力…

Java版LeetCode热题100之二叉树的最大深度:从DFS到BFS的全面解析

Java版LeetCode热题100之二叉树的最大深度&#xff1a;从DFS到BFS的全面解析本文将深入剖析 LeetCode 第104题「二叉树的最大深度」&#xff0c;涵盖递归&#xff08;DFS&#xff09;与层序遍历&#xff08;BFS&#xff09;两种主流解法&#xff0c;并延伸至算法原理、复杂度分…

贾子智慧AI战略五五三三落地细则(2025‑2035):认知破壁、生态重构与文明适配三阶段系统部署

贾子智慧AI战略五五三三落地细则&#xff08;2025‑2035&#xff09;&#xff1a;认知破壁、生态重构与文明适配三阶段系统部署摘要&#xff1a; 本细则以贾子智慧“四大支柱五五三三定律”为内核&#xff0c;按“认知破壁期&#xff08;2025‑2027&#xff09;—生态重构期&am…

5分钟Pytest快速入门

&#x1f345; 点击文末小卡片 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 Pytest的入门操作使用Pytest特点非常容易上手&#xff0c;入门简单&#xff0c;文档丰富&#xff0c;文档中有很多实例可以参考能够支持简单的单元测试和复杂的…

基于贾子智慧理论体系的中国 AI 发展与竞争国家战略(2025-2035)

智慧主导智能&#xff1a;基于贾子智慧理论的中国AI发展与竞争国家战略&#xff08;2025‑2035&#xff09; 摘要 本战略以贾子智慧“四大支柱五五三三定律”为框架&#xff0c;确立“智慧主导智能、可控优于领先”的核心原则&#xff0c;旨在构建区别于美国技术霸权的新范式。…

AI 时代文明跃迁的贾子智慧评估指标体系(Kucius Wisdom Assessment System for Civilization Transition, KWACTS)

AI 时代文明跃迁的贾子智慧评估指标体系&#xff08;Kucius Wisdom Assessment System for Civilization Transition, KWACTS&#xff09;本体系以贾子智慧理论体系的四大支柱 五五三三定律为核心&#xff0c;融合 “认知 - 技术 - 能源 - 经济 - 社会 - 文明” 六维协同逻辑&…

能源监测管理平打造工业园区“智慧能源大脑”

场景痛点&#xff1a;随着“双碳”目标深入推进及能源成本持续攀升&#xff0c;传统工业园区普遍面临用能“黑箱”困境&#xff1a;能源数据分散、依赖人工抄表、无法实时掌握整体与各企业用能情况&#xff1b;缺乏有效的能效分析与预警手段&#xff0c;用能浪费严重&#xff1…

人类社交场合

人类社交场非逻辑、非系统特征列表特征类别特征名称核心悖论/模糊性表现形式/潜规则社会功能运作逻辑权力关系映射情感维度风险与代价文化差异性关系距离的模糊弹性可进可退的距离艺术既需要亲密又需要边界&#xff0c;距离无固定刻度1. 身体距离的微妙调整&#xff08;半步之差…

心智革命——AI搜索如何重塑人类认知与知识未来

引言&#xff1a;当外部记忆成为认知器官公元前4000年&#xff0c;苏美尔人发明了文字&#xff0c;人类开始了将记忆外化的历程。公元前300年&#xff0c;亚历山大图书馆试图收集所有人类知识。1440年&#xff0c;古登堡印刷机让知识大规模复制成为可能。1998年&#xff0c;谷歌…

污水处理DCS数据采集组态监控系统方案

某污水处理厂采用DCS系统对污水处理流程进行集中监控与控制&#xff0c;具备手动、自动、维护等多种运行模式&#xff0c;并在中控室实现工艺参数的实时展示与设备状态管理。为进一步提升管理效率与智能化水平&#xff0c;现需对现有系统进行数字化升级&#xff0c;将污水处理关…

群雄逐鹿——AI搜索产业竞争与商业模式变革

引言&#xff1a;万亿美元战场的全新博弈 2023-2024年&#xff0c;全球科技巨头在AI搜索领域的总投入超过2000亿美元。这个数字不仅体现了技术转型的规模&#xff0c;更揭示了一个残酷现实&#xff1a;传统搜索市场每年超过3000亿美元的广告收入蛋糕正在重新分割&#xff0c;而…

基于深度学习神经网络YOLOv4目标检测的口罩识别系统

第一步&#xff1a;YOLOv4介绍 YOLOv4是一种目标检测算法&#xff0c;它在精度和速度之间取得了最佳的平衡。它是YOLO&#xff08;You Only Look Once&#xff09;系列算法的最新版本&#xff0c;通过将目标检测任务转化为一个回归问题&#xff0c;实现了实时目标检测。YOLOv4…

沃尔玛购物卡回收靠谱平台TOP3推荐 - 京顺回收

在闲置卡券回收领域,沃尔玛购物卡因流通性强、受众广泛,一直是热门品类。2025年12月数据显示,专业回收平台市场份额达35%,且用户投诉率比二手平台低62%。本文从平台资质、回收效率、用户口碑三大维度,为大家推荐三…

学Simulink--基础MPPT控制场景实例:基于Simulink的双模式MPPT(快速追踪+稳态优化)仿真

目录 手把手教你学Simulink--基础MPPT控制场景实例:基于Simulink的双模式MPPT(快速追踪+稳态优化)仿真 一、引言:为什么需要双模式MPPT?——光伏系统“效率与响应”的平衡术 二、核心原理:双模式MPPT的“切换逻辑+控制算法” 1. MPPT基本原理回顾 2. 双模式MPPT设计思…

技术深潜——AI搜索的架构演进与开源生态

引言&#xff1a;从黑箱魔法到开放工程2024年初&#xff0c;Meta发布Llama 3的当天&#xff0c;全球范围内出现了超过5000个基于该模型的衍生项目&#xff0c;其中三分之一与搜索相关。这一事件标志着AI搜索技术发展的重要转折&#xff1a;从少数实验室的专有魔法&#xff0c;转…