我有一个类似于以下内容的(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
我希望有人能够证明如何最好地执行这种类型的更新。我感谢任何帮助,技巧或示例。道歉,如果这是显而易见的。
假设您正在使用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()。再次允许,但不寻常。
PersonSales
sum()