在表中的行之间复制数据
在数据库管理中,经常需要根据表中其他行的数据来更新行同一张桌子。考虑一个包含 ID、NAME 和 VALUE 列的表,其中包含重复的 NAME 值,如下所示:
ID | NAME | VALUE | ---------------------------- 1 | Test | VALUE1 | 2 | Test2 | VALUE2 | 1 | Test2 | | 4 | Test | | 1 | Test3 | VALUE3 |
假设我们要更新具有重复 NAME 值的行中的空 VALUE 字段。为了实现这一点,我们可以使用引用和更新同一个表中的值的 SQL 查询。
一种方法涉及使用带有联接的 UPDATE 语句。在以下查询中,我们连接 data_table 两次,将它们别名为 dt1 和 dt2:
UPDATE data_table dt1, data_table dt2 SET dt1.VALUE = dt2.VALUE WHERE dt1.NAME = dt2.NAME AND dt1.VALUE = '' AND dt2.VALUE != ''
此查询标识空 VALUE 字段(其中 dt1.VALUE 为空)并将其更新为非空来自具有相同名称的其他行的 VALUE(其中 dt2.VALUE 不为空)。
As另一种方法是,我们可以使用子查询来识别具有非空值的行,并将其连接回原始表进行更新:
UPDATE data_table t, (SELECT DISTINCT ID, NAME, VALUE FROM data_table WHERE VALUE IS NOT NULL AND VALUE != '') t1 SET t.VALUE = t1.VALUE WHERE t.ID = t1.ID AND t.NAME = t1.NAME
这两个查询都会产生所需的输出:
ID | NAME | VALUE | ---------------------------- 1 | Test | VALUE1 | 2 | Test2 | VALUE2 | 1 | Test2 | VALUE2 | 4 | Test | VALUE1 | 1 | Test3 | VALUE3 |
这些方法提供了操作表中数据的灵活性,允许您根据包含同一表中其他行的条件更新值。
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3