想象一下下表(称为TestTable):
id somedate somevalue
-- -------- ---------
45 01/Jan/09 3
23 08/Jan/09 5
12 02/Feb/09 0
77 14/Feb/09 7
39 20/Feb/09 34
33 02/Mar/09 6
Run Code Online (Sandbox Code Playgroud)
我想要一个以日期顺序返回运行总计的查询,例如:
id somedate somevalue runningtotal
-- -------- --------- ------------
45 01/Jan/09 3 3
23 08/Jan/09 5 8
12 02/Feb/09 0 8
77 14/Feb/09 7 15
39 20/Feb/09 34 49
33 02/Mar/09 6 55
Run Code Online (Sandbox Code Playgroud)
我知道在SQL Server 2000/2005/2008中有各种方法可以做到这一点.
我对使用aggregate-set-statement技巧的这种方法特别感兴趣:
INSERT INTO @AnotherTbl(id, somedate, somevalue, runningtotal)
SELECT id, somedate, somevalue, null
FROM TestTable
ORDER …Run Code Online (Sandbox Code Playgroud) 我有一个情况,我有一个巨大的表,包含大量的行,看起来像(例如):
id Timestamp Value
14574499 2011-09-28 08:33:32.020 99713.3000
14574521 2011-09-28 08:33:42.203 99713.3000
14574540 2011-09-28 08:33:47.017 99713.3000
14574559 2011-09-28 08:38:53.177 99720.3100
14574578 2011-09-28 08:38:58.713 99720.3100
14574597 2011-09-28 08:39:03.590 99720.3100
14574616 2011-09-28 08:39:08.950 99720.3100
14574635 2011-09-28 08:39:13.793 99720.3100
14574654 2011-09-28 08:39:19.063 99720.3100
14574673 2011-09-28 08:39:23.780 99720.3100
14574692 2011-09-28 08:39:29.167 99758.6400
14574711 2011-09-28 08:39:33.967 99758.6400
14574730 2011-09-28 08:39:40.803 99758.6400
14574749 2011-09-28 08:39:49.297 99758.6400
Run Code Online (Sandbox Code Playgroud)
好的,所以规则是:时间戳可以是任意n秒,5s,30s,60s等,它取决于记录的年龄(存档发生).
我希望能够查询此表以根据时间戳选择每个第n行.
例如:
从mytable中选择*,其中intervalBetweenTheRows = 30s
(出于这个问题的目的,基于假设,所请求的间隔总是比数据库中的可用精度更高)
所以,每第n行根据每行之间的时间
有任何想法吗?!
卡尔
对于那些感兴趣的人来说,递归CTE实际上非常慢,我想到了一个稍微不同的方法:
SELECT TOP 500
MIN(pvh.[TimeStamp]) as [TimeStamp],
AVG(pvh.[Value]) as [Value] …Run Code Online (Sandbox Code Playgroud) 样本表ID :( num是一个键,因此不会有任何重复)
num
1
5
6
8
2
3
Run Code Online (Sandbox Code Playgroud)
期望的输出:(
应该排序并具有累积和列)
num cumulative
1 1
2 3
3 6
5 11
6 17
8 25
Run Code Online (Sandbox Code Playgroud)
这是我得到的一个解决方案:
select a.num, sum(b.num) from ID a, ID b where b.num <= a.num group by a.num order by a.num;
Run Code Online (Sandbox Code Playgroud)