Navicat 博客

一条语句更新多个表 2022 年 11 月 17 日,由 Robert Gravelle 撰写

众所周知,多个服务器命中会减慢应用程序的速度。出于这个原因,开发人员致力于找尋使用最少的语句更新数据的最有效方法。事实证明,SQL UPDATE 语句确实支持使用以下语法设置多个表的字段:

UPDATE table1, table2, ...
    SET column1 = value1,
        column2 = value2,
        ...
[WHERE conditions]

语法是由组合两个或多个表的各种关键字组成,例如 join 关键字。

今天的文章将概述多表 UPDATE 语句,以及使用 MySQL 8 和 Navicat Premium 16 作为示例。

注意事项

将两个表更新合并为一条语句并非没有限制和准则。请记住以下几点:

  • 在多表 UPDATE 查询中,每条满足条件的记录都会被更新。即使记录多次匹配条件,该行也只会更新一次。
  • 更新多个表的语法不能与 ORDER BY 和LIMIT 关键字一起使用。

因此,虽然多表 UPDATE 语句非常有效,但它并不适用于所有情况。

实际例子

为了尝试使用多表 UPDATE 语句,我们将创建两个名为“library”和“book”的表,并设想一下从图书馆借了一本或多本书。这样做会同时增加和减少图书的数量。事实证明,这是将两个单独的语句合并为一个 UPDATE 查询的理想方案。这可以避免对服务器的单独调用,令操作更有效率。

以下是每个表的定义和内容:

library 表

library_table_definition (32K)

library_table_contents (18K)

book 表

book_table_definition (38K)

book_table_contents (17K)

以下的查询将更新两个表:

UPDATE library l, book b
    SET l.book_count = l.book_count - 2,
        b.book_count = b.book_count + 2
WHERE l.id = b.book_id
AND b.id = '1AG';

在上面的查询中,l.id = b.book_id 条件充当一个内部联接,将两个表结合在一起,并在检查表约束后对组合表进行操作。同时,b.id = '1AG' 条件进一步将目标行减少为与用户 '1AG' 相关的行。

我们也可以使用其他联接类型,如外部联接和右外联接;唯一的弱点是分组的两个表必须具有相似或匹配的属性。

与常规(单个表)UPDATE 语句一样,SET 关键字与 UPDATE 关键字会一起用于在现有行中设置新值。旧值会被新数据覆盖。我们可以在下面的 Navicat 中查看查询结果:

update_result (44K)

正如预期的那样,用户 '1AG' 和图书 103 的计数已在两个表中更新:

updated_table_contents (27K)

总结

今天的文章概述了多表 UPDATE 语句,以及使用 MySQL 8 和 Navicat Premium 16 作为示例。我们学习到多表 UPDATE 语句最适合对相关表列应用数学运算,例如递增和递减。

Navicat 文章
频道条目
分享
文章归档