彩票走势图

数据库管理工具Navicat Premium使用教程:一条语句更新多个表

翻译|使用教程|编辑:秦林|2022-11-28 13:51:16.493|阅读 753 次

概述:如何在Navicat 16版本实现一条语句更新多个表,小编通过本文给大家具体介绍,欢迎下载最新版试用体验。

# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>


Navicat Premium正版试用下载

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

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

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

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

1、注意事项

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

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

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

2、实际例子

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

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

library 表

book 表

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 中查看查询结果:

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

3、总结

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

Navicat Premium是一个可连接多种数据库的管理工具,它可以让你以单一程序同时连接到MySQL、Oracle及PostgreSQL等数据库,让管理不同类型的数据库更加的方便。慧都2022年终狂欢活动火热进行中,全场产品超低价来袭,Navicat系列产品最高直降600元,了解更多活动详情,请咨询。


数据库管理工具交流群:7645665608  欢迎进群交流讨论

正版数据库管理软件下载、购买、授权咨询,请点这里!


标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@cahobeh.cn


为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
相关产品
Navicat for MySQL

Navicat for MySQL 是一套管理和开发 MySQL 或 MariaDB 的理想解决方案。

Navicat for PostgreSQL

Navicat for PostgreSQL是一套专为PostgreSQL设计的强大数据库管理及开发工具

Navicat for Oracle

Navicat for Oracle是一套超强的Oracle数据库系统管理工具,包括数据模型工具、数据或结构同步、导入或导出、和报表,令维护数据的进程更容易。

Navicat Premium

Navicat Premium 是一套数据库管理工具,让你使用一个程序即可同時连接到 MySQL、MariaDB、SQL Server、SQLite、Oracle 和 PostgreSQL 数据库。

title
title
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP