MySQL根据 ID 将表 B 的字段更新到表 A的实战教程

 更新时间:2026年04月30日 09:22:08   作者:deviant-ART  
这篇文章主要介绍了MySQL根据 ID 将表 B 的字段更新到表 A的实战教程,本文将系统梳理几种常见写法,并分析它们的优缺点,需要的朋友可以参考下

在日常开发中,我们经常会遇到这样一个需求:

将表 a 中的字段 AB,更新为表 b 中对应的字段值,条件是两张表的 id 相等。

这个问题看似简单,但在 MySQL 中其实有多种实现方式,不同写法在性能、安全性、适用场景上都有差异。本文将系统梳理几种常见写法,并分析它们的优缺点。

一、推荐写法:UPDATE JOIN(最常用)

UPDATE a
JOIN b ON a.id = b.id
SET 
    a.A = b.A,
    a.B = b.B;

✔ 特点

  • 性能好(利用 JOIN)
  • 语义清晰
  • 只更新匹配到的记录
  • 不会误更新为 NULL

✔ 适用场景

👉 绝大多数情况优先使用

二、写法二:多表 UPDATE(逗号写法)

UPDATE a, b
SET 
    a.A = b.A,
    a.B = b.B
WHERE a.id = b.id;

✔ 特点

  • MySQL 早期语法
  • 本质上等价于 JOIN

⚠️ 不足

  • 可读性稍差
  • 不够直观

三、写法三:子查询方式

UPDATE a
SET 
    A = (SELECT b.A FROM b WHERE b.id = a.id),
    B = (SELECT b.B FROM b WHERE b.id = a.id);

✔ 特点

  • 写法直观
  • 不需要 JOIN

⚠️ 风险点(非常重要)

如果某条 a.id 在表 b 中 不存在匹配

👉 子查询返回 NULL
👉 会执行:

A = NULL,
B = NULL

❗ 结果

可能导致数据被“误清空”

四、改进写法:结合 EXISTS(更安全)

UPDATE a
SET 
    A = (SELECT b.A FROM b WHERE b.id = a.id),
    B = (SELECT b.B FROM b WHERE b.id = a.id)
WHERE EXISTS (
    SELECT 1 FROM b WHERE b.id = a.id
);

✔ 优点

  • 只更新存在匹配的数据
  • 避免被更新为 NULL

⚠️ 不足

  • 性能通常不如 JOIN
  • 写法稍复杂

五、核心差异解析

写法是否更新全部行未匹配时行为推荐程度
JOIN不更新⭐⭐⭐⭐⭐
多表 UPDATE不更新⭐⭐⭐⭐
子查询更新为 NULL⭐⭐
子查询 + EXISTS不更新⭐⭐⭐

六、示例对比

表 a

idA
1x
2y

表 b

idA
1z

👉 使用子查询(无 EXISTS)

结果:

idA
1z
2NULL ❗

👉 使用 JOIN

结果:

idA
1z
2y

七、最佳实践建议

✅ 1. 优先使用 JOIN

UPDATE a
JOIN b ON a.id = b.id
SET a.A = b.A, a.B = b.B;

✅ 2. 确保关联字段唯一

  • b.id 最好是主键或唯一索引
  • 避免一对多导致更新异常

✅ 3. 重要操作先 SELECT 验证

SELECT a.id, a.A, b.A
FROM a
JOIN b ON a.id = b.id;

✅ 4. 生产环境加 WHERE 限制

避免误更新全表:

WHERE a.id IN (....)

八、总结

这个问题的本质是:跨表更新数据

虽然 MySQL 提供了多种写法,但从稳定性和性能角度来看:

👉 UPDATE JOIN 是最推荐的标准解法

同时要特别注意:

⚠️ 子查询写法在未匹配时会写入 NULL
⚠️ 这是很多线上事故的常见原因

到此这篇关于MySQL根据 ID 将表 B 的字段更新到表 A的实战教程的文章就介绍到这了,更多相关mysql 字段更新内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 保证MySQL与Redis数据一致性的6种实现方案

    保证MySQL与Redis数据一致性的6种实现方案

    这篇文章将聚焦在一个非常重要且复杂的问题上:MySQL与Redis数据的一致性,当我们在应用中同时使用MySQL和Redis时,如何保证两者的数据一致性呢?下面就来分享几种实用的解决方案,需要的朋友可以参考下
    2024-03-03
  • SQL使用复合索引实现数据库查询的优化

    SQL使用复合索引实现数据库查询的优化

    这篇文章主要介绍了SQL使用复合索引实现数据库查询的优化,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-05-05
  • MySQL中datetime时间字段的四舍五入操作

    MySQL中datetime时间字段的四舍五入操作

    这是由一则生产环境问题引出的MySQL对于datetime时间类型字段中毫秒的处理的深究,这篇文章主要给大家介绍了关于MySQL中datetime时间字段的四舍五入操作的相关资料,需要的朋友可以参考下
    2021-09-09
  • MySql修改数据库编码为UTF8避免造成乱码问题

    MySql修改数据库编码为UTF8避免造成乱码问题

    mysql 创建数据库时指定编码很重要,很多开发者都使用了默认编码,乱码问题可是防不胜防,下面与大家分享下通过修改数据库默认编码方式为UTF8来减少数据库创建时的设置,避免因粗心造成的乱码问题
    2013-06-06
  • SQL删除重复数据的实例教程

    SQL删除重复数据的实例教程

    在使用SQL提数的时候,常会遇到表内有重复值的时候,下面这篇文章主要给大家介绍了关于SQL删除重复数据的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2022-07-07
  • mysql使用Haversine 公式和ST_Distance_Sphere 函数实现附近的人功能

    mysql使用Haversine 公式和ST_Distance_Sphere 函数实现附近的人功能

    使用 MySQL 来实现“附近的人”功能,可以通过Haversine 公式和ST_Distance_Sphere 函数两种方式来实现,这篇文章主要介绍了mysql实现附近的人功能,需要的朋友可以参考下
    2023-08-08
  • MYSQL复杂查询练习题以及答案大全(难度适中)

    MYSQL复杂查询练习题以及答案大全(难度适中)

    在我们学习mysql数据库时需要一些题目进行练习,下面这篇文章主要给大家介绍了关于MYSQL复杂查询练习题以及答案的相关资料,文中通过实例代码介绍的非常详细,这些练习题难度适中,需要的朋友可以参考下
    2022-08-08
  • java实现mysql自动更新创建时间与更新时间的两种方式

    java实现mysql自动更新创建时间与更新时间的两种方式

    在实际开发中,每条数据的创建时间和修改时间,尽量不需要应用程序去记录,而由数据库获取当前时间自动记录创建时间,本文主要介绍了java实现mysql自动更新创建时间与更新时间的两种方式,感兴趣的可以了解一下
    2024-01-01
  • mysql使用insert into select插入查出的数据

    mysql使用insert into select插入查出的数据

    这篇文章主要介绍了mysql使用insert into select插入查出的数据方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • MySQL重定位数据目录的方法

    MySQL重定位数据目录的方法

    这篇文章主要介绍了MySQL重定位数据目录的实现方法,分析了重定位MySQL数据目录的实现原理与技巧,具有一定的参考借鉴价值,需要的朋友可以参考下
    2014-12-12

最新评论