相关疑难解决方法(0)

计算SQL Server中的运行总计

想象一下下表(称为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)

sql t-sql sql-server running-total

158
推荐指数
8
解决办法
23万
查看次数

SQL以不同的间隔选择行

我有一个情况,我有一个巨大的表,包含大量的行,看起来像(例如):

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)

sql sql-server

6
推荐指数
1
解决办法
4385
查看次数

在MySQL中创建累积和列

样本表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)

mysql sql

4
推荐指数
1
解决办法
4063
查看次数

标签 统计

sql ×3

sql-server ×2

mysql ×1

running-total ×1

t-sql ×1