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



我正在尝试向表中添加几列,我已经做到了,但不清楚为什么会失败。这是一个示例起始表。。。

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

我想坐上面的桌子。。。

1) 按年份、名称和值排序2) 基于#1,添加"有序"列,该列为每组年份和名称提供一个数字,其中值按升序排列3) 被乘数列是Amount乘以Ordered4) 对相乘的列求和,并对每组求和

结果。。。

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

除了最后一列,我什么都有,因为我一直在出错。。。

"Row_Number附近的表达式无效"。

"有序"的SQL。。。

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

"乘法"的SQL。。。

 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;

相关内容

最新更新