您现在的位置是:主页 > 数据库技术 > 数据库技术

mysql跨表更新怎么实现

IDCBT2022-01-12服务器技术人已围观

简介本篇内容介绍了“mysql跨表更新怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅

本篇内容介绍了“mysql跨表更新怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

 背景

项目新导入了一批人员数据,这些人的有的部门名称发生了变化,有的联系方式发生了变化,暂且称该表为

t_dept_members, 系统中有另外一张表 t_user_info 记录了人员信息。要求将 t_dept_members 中有变化的信息更新到 t_user 表中,这个需求就是「跨表更新」啦

憨B SQL 直接被秒杀

不带脑子出门的就写出了下面的 SQL

看到身后 DBA 小段总在修仙,想着让他帮润色一下?,于是发给了他,然后甩手回来就是这个样子:

看到这个 SQL 语句我都惊呆了,还能这样写,在无情的嘲笑下,一声 KO 我直接倒下。死也得死的明白,咱得查查这是咋回事啊

Mysql Update Join

我们经常使用 join 查询表中具有(在 INNER JOIN 情况下)或可能没有(在 LEFT JOIN 情况下)另一个表中匹配行的表中的行。

同样,在 MySQL 中, 我们也可以在 UPDATE 语句中使用 JOIN 子句执行跨表更新,语法就是这样:

UPDATE T1, T2,  [INNER JOIN | LEFT JOIN] T1 ON T1.C1 = T2. C1  SET T1.C2 = T2.C2,      T2.C3 = expr  WHERE condition

我们还是详细的说明一下上面的语法:

     首先,在 UPDATE 子句之后,指定主表(T1)和希望主表联接到的表(T2)。请注意,必须在UPDATE 子句之后至少指定一个表

     接下来,指定你要使用的联接类型,即 INNER JOIN 或 LEFT JOIN 以及联接谓词。 JOIN子句必须出现在 UPDATE 子句之后(这个大家都是知道的哈)

     然后,将新值分配给要更新的 T1或 T2 表中的列

     最后,在 WHERE 子句中指定一个条件以将行限制为要更新的行

    如果你遵循 update 语法,你会发现有另外一种语法也可以完成跨表更新

    UPDATE T1, T2  SET T1.c2 = T2.c2,        T2.c3 = expr  WHERE T1.c1 = T2.c1 AND condition

    上面的语法其实隐式使用了 inner join 关键字,完全等同于下面的样子:

    UPDATE T1,T2  INNER JOIN T2 ON T1.C1 = T2.C1  SET T1.C2 = T2.C2,        T2.C3 = expr  WHERE condition

    个人建议还是加上 inner join 关键字吧,这样可读性更好,尽享丝滑,你觉得呢?

    我摸鱼看到的,觉得是灵魂翻译

    标签:

    很赞哦! ()

本栏推荐