需求11——解决字段无法清空的两个小bug

embedded/2024/10/15 20:24:25/

 

目录

背景

第一个小bug——问题阐述

第一个小bug——解决方案

第二个小bug——问题阐述

第二个小bug——解决方案

总结


背景

已经写了一个上午的文章了,写完这篇就可以去吃饭了。这也是这几个月的我写的最后一个小bug文章,把这篇文章写完就搞定了。

第一个小bug——问题阐述

具体情况是这样的:当用户在界面上清空“知会干系人”字段后,点击保存,系统并没有实际清空该字段。类似地,当用户清空“设备名称”字段后,保存操作也没有生效,提交后发现该字段依然保留了之前的内容。

因此,我们的目标是确保在用户清空“知会干系人”和“设备名称”字段后,保存操作能够正确生效,真正实现字段的清空。

第一个小bug——解决方案

我们先来研究一下“知会干系人”无法清空的问题:首先找到更新“知会干系人”的接口,并查看其更新逻辑。

此时,我们再次检查系统是否能够清空字段,结果发现可以成功清空。

这个小问题已经解决了。

第二个小bug——问题阐述

接下来,我们来看下一个小问题。

然后我重新查看了一下作业标准,发现它并没有更新。

第二个小bug——解决方案

这时,我们应该检查一下后端的 PUT 接口,看看工作内容及标准是否已经更新到数据库中。

可以看到,PUT 接口的负载是没有问题的。因为设备名称是根据 deviceId 来查询的,按理说我把设备名称清空后,deviceId 应该为 null。从负载上看,确实如此。然而,当我们查看数据库时,发现数据库并没有更新。这意味着 PUT 接口可能存在问题。

我们进入这个接口,查看它是如何将信息更新到数据库中的。

也就是说,这个接口的更新操作使用的是 saveOrUpdateBatch 方法。然而,在使用 MyBatis-Plus 生成的 saveOrUpdate 方法时,有些字段需要更新为空值。但 MyBatis-Plus 默认的策略是 NOT_NULL,即如果字段为空,则不会更新该字段。

这就是为什么数据库中的 deviceId 无法更新为 null,因为在更新时 deviceId 为 null,这会导致 saveOrUpdate 方法忽略该字段的更新。

然后我上网查了一下如何让这个字段更新为 null,结果发现可以这样做:在 deviceId 字段上使用 @TableField 注解,并设置 updateStrategy 属性为 FieldStrategy.IGNORED

然后再去系统上测试一下看看效果,发现这个小 bug 已经被解决了,数据库中的 deviceId 字段也已经可以被更新为 null 了。

总结

这两个小 bug 虽然都是无法清空,但它们无法清空的原因并不相同。

  1. 知会干系人无法清空

    • 原因:tshList[] 这个知会干系人数组没有值时,就不会执行更新知会干系人的操作。
  2. 设备名称无法被清空

    • 原因:在 MyBatis-Plus 中,如果使用了 saveOrUpdate 方法进行更新时,假如你想把某个字段更新为 null 是不可以的。该方法会自动忽略这种更新,只有非空值才会被更新。

http://www.ppmy.cn/embedded/128054.html

相关文章

工资保证金监管平台有多重要?

近期有很多农民工讨要工资无果的新闻,民工工资支付问题一直是社会关注的焦点,工资拖欠问题影响了很多农民工的基本生活,那么很多地方的人社局就通过科技手段使农民工工资的支付能够更加透明、更加的智能化,确保农民工能够按时收到…

unity ps 卡通角色自制

一、PS的使用 1.画头 按U键打开画椭圆工具,红色框内选择形状填充色和描边,默认是画椭圆,按住Shift即可画圆 2.画眼睛 按照步骤一的操作画两个填充椭圆就行,然后CtrlG打组,再CtrlJ复制即可 3.画鼻子、嘴、身体、脚 同…

C level人才招聘

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗?订阅我们的简报,深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同,从行业内部的深度分析和实用指南中受益。不要错过这个机会,成为AI领…

【专题】2024年经销商车后用户研究:洞察车主变化制胜售后未来报告合集PDF分享(附原数据表)

原文链接:https://tecdat.cn/?p37875 在汽车行业快速变革的时代,“互联网原住民”成为车主群体的重要组成部分。2023 - 2024 年,车后用户线上渠道使用比例不断上升,App/小程序备受青睐,各线上渠道各具优势。同时&am…

redis高级(面试题一)

目录 一、Redis持久化机制有哪些?有什么区别? 1、RDB(redis database) 2、AOF 3、区别 二、redis的主从集群有什么用? 1、什么是redis的主从集群 2、为什么要使用redis主从集群(也就是有什么用) 三、redis的哨兵…

【内网映射】frps实现内网映射

1. 简介 在当今互联网时代,远程访问内网资源已成为一种常见需求。无论是在家访问办公室的电脑,还是远程管理家庭NAS,内网映射都是一种强大的解决方案。 本文将详细介绍如何使用frp(Fast Reverse Proxy)来实现这一目标。 1.1 frp frp是一个高性能的反向代理应用,可以帮助您轻…

(AtCoder Beginner Contest 375) 题解(下)

一、题解 第 E 题 3 Team Division 一眼看像背包,观察数据范围,合法的总能力值 ≤ 500 \le 500 ≤500,那么我们可以设计一个背包DP: int dp[110][510][510]; //dp[i][j][k] 表示前 i 个人,分给第一组的能力值是 j&…

使用Python抓取并分析外汇汇率数据

使用Python抓取并分析外汇汇率数据 在当今全球化的经济环境中,了解不同货币之间的汇率是非常重要的。对于个人投资者、旅行者以及企业来说,准确及时的汇率信息可以帮助他们做出更加明智的决策。本文将介绍如何使用Python编程语言来从网络上获取最新的外…