首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MySQL中具有表比较的多个更新

MySQL中具有表比较的多个更新
EN

Stack Overflow用户
提问于 2013-02-15 08:45:02
回答 2查看 38关注 0票数 0

我不知道如何使用一个查询进行多个更新。

这是我的两张桌子。

devices_table

代码语言:javascript
复制
DeviceID  Brand     SerialNumber
---------------------------------
1         Nintendo  324234324
2         Nintendo  89978333
3         Sony      Z3432343
4         Sony      Z3424335

temporary_table

代码语言:javascript
复制
DeviceID  Brand     SerialNumber
---------------------------------
NULL      Nintendo  324234324
NULL      Nintendo  89978333
NULL      Sony      Z3432343
NULL      Sony      Z3424335

我将如何在DeviceID中填写temporary_table?我需要什么样的查询?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-02-15 08:52:18

您需要使用update语句:

代码语言:javascript
复制
UPDATE  temporary_table
SET     DeviceID = (    SELECT  Devices_table.DeviceID
                        FROM    Devices_table
                        WHERE   Devices_table.Brand = temporary_table.Brand
                        AND     Devices_table.SerialNumber = temporary_table.SerialNumber
                    );

SQL Fiddle示例

或者可以使用联接而不是关联子查询:

代码语言:javascript
复制
UPDATE  temporary_table
        INNER JOIN Devices_table
            ON Devices_table.Brand = temporary_table.Brand
            AND Devices_table.SerialNumber = temporary_table.SerialNumber
SET     temporary_table.DeviceID = Devices_table.DeviceID;

SQL Fiddle示例

票数 2
EN

Stack Overflow用户

发布于 2013-02-15 08:56:23

是的,您可以使用以下查询:

代码语言:javascript
复制
UPDATE  temporary_table
SET     DeviceID = Devices_table.DeviceID
FROM    temporary_table
INNER JOIN Devices_table
ON Devices_table.Brand = temporary_table.Brand
AND Devices_table.SerialNumber = temporary_table.SerialNumber;
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14890907

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档