【发布时间】:2016-03-31 19:31:22
【问题描述】:
给定下表:
create table #T
(
user_id int,
project_id int,
datum datetime,
status varchar(10),
KM int
)
insert into #T values
(1, 1, '20160301 10:25', 'START', 1000),
(1, 1, '20160301 10:28', 'PASS', 1008),
(2, 2, '20160301 10:29', 'START', 2000),
(1, 1, '20160301 11:08', 'STOP', 1045),
(3, 3, '20160301 10:25', 'START', 3000),
(2, 2, '20160301 10:56', 'STOP', 2020),
(1, 4, '20160301 15:00', 'START', 1045),
(4, 5, '20160301 15:10', 'START', 400),
(1, 4, '20160301 15:10', 'PASS', 1060),
(1, 4, '20160301 15:20', 'PASS', 1080),
(1, 4, '20160301 15:30', 'STOP', 1080),
(4, 5, '20160301 15:40', 'STOP', 450),
(3, 3, '20160301 16:25', 'STOP', 3200)
我必须对给定用户和项目的 START 和 STOP 状态之间的轨道长度求和 预期的结果是这样的:
user_id project_id datum TOTAL_KM
----------- ----------- ---------- -----------
1 1 2016-03-01 45
1 4 2016-03-01 35
2 2 2016-03-01 20
3 3 2016-03-01 200
4 5 2016-03-01 50
如何在不使用集群的情况下实现这一目标? 性能是个问题(我每个月有超过 100 万条记录,我们必须保留数据好几年)
说明: 我们可以忽略状态为“PASS”的记录。基本上,我们必须从给定用户和项目的 STOP 记录中减去 START 记录的 KM 值。 START 和 STOP 之间可能有数百条记录(如示例数据中所述) 日期应该是 START 日期(如果我们有超过午夜交货的情况)
我认为我应该有一个带有 OVER() 子句的 SELECT,但我不知道如何制定我的查询来尊重这些条件。
有什么想法吗?
【问题讨论】:
-
您使用的是什么版本的 SQL Server?
标签: sql-server subtotal