首页 > 数据库 > mysql教程 > 如何使用 SQL 使用另一个表的总和更新表字段?

如何使用 SQL 使用另一个表的总和更新表字段?

Linda Hamilton
发布: 2024-12-22 19:23:11
原创
561 人浏览过

How to Update a Table Field with the Sum from Another Table Using SQL?

使用聚合函数的 SQL 更新查询

本题探讨了 SQL 更新查询中聚合函数的使用。用户尝试使用另一个表中的值的总和来更新表中的字段。然而,由于语法问题,他们的查询不起作用。

分析

用户提出的初始查询包含两个主要缺陷:

  1. 混合使用 SET 和 GROUP BY 子句:SET 不支持 GROUP BY,反之反之亦然。
  2. 在 SET 子句中直接使用聚合函数 (SUM):SET 需要单个值,而不是聚合。

解决方案

要解决这些问题,必须使用子查询。子查询将计算第二个表中的值的总和,并按公共字段分组。然后,该子查询的结果将与第一个表连接,并用于相应地更新字段。

正确的查询:

UPDATE t1
SET t1.field1 = t2.field2Sum
FROM table1 t1
INNER JOIN (select field3, sum(field2) as field2Sum
   from table2
  group by field3) as t2
on t2.field3 = t1.field3
登录后复制

在此查询中:

  • 子查询针对field3的每个唯一值计算table2中field2的总和。
  • 外部查询连接table1 的子查询结果使用 field3 字段。
  • table1 的 field1 使用子查询中计算的 field2Sum 进行更新。

以上是如何使用 SQL 使用另一个表的总和更新表字段?的详细内容。更多信息请关注PHP中文网其他相关文章!

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