一尘不染

SQL如何更新同一表中组上方的列的SUM

sql

我有一个类似于以下内容的(SQL Server)表:

销售摘要

2013      1          Jim             $10                  ??

2013      1         Anna            $0                   ??

2013      2         John             $8                   ??

2013      3        Todd              $4                   ??

2013      3        Alan               $1                   ??

2014      3        Alan              $22                  ??

我试图对这个示例SalesSummary表进行汇总,然后将正确的值插入“团队销售”列中。在此示例中,我希望第一列和第二列中的金额为10美元,第三列中的金额为8美元,第四列/
5位的金额为5美元,第六列的插槽为22美元。原谅我对SQL的无知,但是我决定告诉我一个糟糕的解决方案,如下所示:

UPDATE SalesSummary SET TeamSales = sum.TeamSales
FROM (SELECT Team, Year, SUM(PersonSales) OVER (Partition By Team, Year) as TeamSales)
      FROM SalesSummary
      GROUP BY Team, Year, PersonSales
     ) AS sum, SalesSummary as SS
WHERE sum.Team = ss.Team AND sum.Year = ss.Year

我希望有人能够证明如何最好地执行这种类型的更新。我感谢任何帮助,技巧或示例。道歉,如果这是显而易见的。


阅读 151

收藏
2021-03-10

共1个答案

一尘不染

假设您正在使用SQL Server,我认为您需要这样的东西:

WITH toupdate AS
     (SELECT team, year, 
             Sum(personsales) OVER (partition BY team, year) AS newTeamSales 
      FROM salessummary
     ) 
UPDATE toupdate 
   SET teamsales = newteamsales;

您的原始查询存在多个问题和可疑的结构。首先,聚合子查询不可更新。其次,您正在进行聚合,并且使用窗口功能(尽管允许)与众不同。第三,你被聚集PersonSales,并采取sum()。再次允许,但不寻常。

2021-03-10