尝试使用 Partition By 和 Row_Number 进行求和运算

Trying to do sum math using Partition By and Row_Number

我正在尝试向我的 table 添加几列,我已经完成了一些,但不清楚为什么会失败。这是一个从 table...

开始的示例
Date        Name    Amount
1/2/2015    Andy    148
2/5/2015    Andy    188
2/11/2015   Andy    154
1/15/2015   John    136
2/5/2015    John    176
1/7/2015    John    134
1/19/2015   John    251
2/21/2015   Carlos  120
2/15/2015   Carlos  211
1/8/2015    Carlos  120
1/2/2014    Andy    151
2/5/2014    Andy    281
2/11/2014   Andy    298 
1/15/2014   John    292
2/5/2014    John    134 
1/7/2014    John    281
1/19/2014   John    101
2/21/2014   Carlos  137
2/15/2014   Carlos  108
1/8/2014    Carlos  292

我想把上面的 table 和...

1) 按年份、名称排序,然后按值排序 2) 基于#1,添加 "Ordered" 列,为每组 Year 和 Name 提供一个数字,其中 Value 设置为升序排序 3) 相乘的列是用 Amount 乘以 Ordered 4)将相乘的列和每个集合的总和相加

结果...

Date    Year    Name    Amount  Ordered   Multiplied    Sum
1/2/2014    2014    Andy    151      1           151    1607
2/5/2014    2014    Andy    281      2           562    1607
2/11/2014   2014    Andy    298      3           894    1607
2/15/2014   2014    Carlos  108      1           108    1258
2/21/2014   2014    Carlos  137      2           274    1258
1/8/2014    2014    Carlos  292      3           876    1258
1/19/2014   2014    John    101      1           101    2380 
2/5/2014    2014    John    134      2           268    2380
1/7/2014    2014    John    281      3           843    2380
1/15/2014   2014    John    292      4           1168   2380
1/2/2015    2015    Andy    148      1           148    1020
2/11/2015   2015    Andy    154      2           308    1020
2/5/2015    2015    Andy    188      3           564    1020
1/8/2015    2015    Carlos  120      1           120    993
2/21/2015   2015    Carlos  120      2           240    993
2/15/2015   2015    Carlos  211      3           633    993
1/7/2015    2015    John    134      1           134    1938
1/15/2015   2015    John    136      2           272    1938
2/5/2015    2015    John    176      3           528    1938
1/19/2015   2015    John    251      4          1004    1938

除了最后一列我什么都有,因为我一直收到错误...

'Invalid expression near Row_Number'.

SQL 对于 'Ordered'...

ROW_NUMBER() OVER ( Partition BY Name, DATEPART(YEAR, Date) ORDER BY Amount ) AS 'Ordered'

SQL 对于 'Multiplied'...

 Amount * Ordered AS Multiplied

现在我可能会天真地想到这个,但我想我可以像这样添加一行...

sum(Multiplied) OVER ( Partition BY Name, DATEPART(YEAR, Date) ORDER BY Amount ) AS 'Sum'

但我不断收到提到的错误。任何想法如何处理?我很高兴听到其他处理数据的方法。我只关心最后一列

如果你的语法有效,它会产生一个累加和。这似乎不是你想要的。

我认为你可以用子查询做你想做的事:

select t.*,
        (seqnum * amount) as multiplied,
        sum(seqnum * amount) over (partition by name, year(date)) as thesum
from (select t.*,
             row_number() over (partition by name, year(date) order by date) as seqnum
      from table t
     ) t;