4

使用给定的表结构(eventTime以秒为单位),我想按给定的时间范围对结果进行分组:

例如:5 分钟

0 to 5:   1 
5 to 10:  2
10 to 15: 3
.....

这如何在 SQL Server 2012 中完成?

谢谢!

弗洛里安

CREATE TABLE [dbo].[evalHubSupply](
[evalHubSupplyId] [int] IDENTITY(1,1) NOT NULL,
[projectId] [int] NOT NULL,
[scenarioId] [int] NOT NULL,
[iterationId] [int] NOT NULL,
[evalExportId] [int] NOT NULL,
[eventType] [varchar](50) NOT NULL,
[eventTime] [int] NOT NULL,
[stopId] [varchar](50) NOT NULL,
[stopName] [varchar](50) NULL,
[vehicleId] [varchar](50) NOT NULL,
[transitLineId] [varchar](50) NULL,
[transitRouteId] [varchar](50) NULL,
[capacity] [int] NULL,
[arrivalTimeAtStop] [int] NULL,
[agentsOnBoard] [int] NULL)

样本数据(间隔 1 小时):

https://dl.dropbox.com/u/481455/table_data.xlsxhttps://dl.dropbox.com/u/481455/table_data_open.ods

“表数据”选项卡包含来自 evalHubSupply 的示例数据。“时间间隔”列计算与 eventTime 相关的间隔(在本例中为每小时)。结果选项卡计算与特定时间间隔相关的事件数量。

4

1 回答 1

1

这将给出每 5 分钟组中的记录数

select eventTime/5,count(*)
from   evalHubSupply
group by eventTime/5
于 2012-10-04T09:06:22.550 回答