如何根据同名其他行的数据更新表中的空值?

Barbara Streisand
发布: 2024-11-13 05:51:02
原创
262 人浏览过

How do I update empty values in a table based on data from other rows with the same name?

在表中的行之间复制数据

在数据库管理中,经常需要根据表中其他行的数据来更新行同一张桌子。考虑一个包含 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 标识并更新空 VALUE 字段(其中 dt1.VALUE 为空)具有相同名称的其他行(其中 dt2.VALUE 不为空)。

作为替代方案,我们可以使用子查询来识别具有非空值的行并将其连接回原始表进行更新:

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 |
登录后复制

这些方法提供了操作表中数据的灵活性,允许您根据包含同一表中其他行的条件更新值。

以上是如何根据同名其他行的数据更新表中的空值?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板