SQL技巧:创建用来按小时报告的查询

喜歡我嗎i

喜歡我嗎i

2016-01-29 16:20

SQL技巧:创建用来按小时报告的查询,SQL技巧:创建用来按小时报告的查询
  要创建一个可以每个小时报告的查询,首先要创建一个表格。该表格一列记录日期,而没有时间信息;另一列记录钟点。下面的表格有一列记录了不同的处理类型。例如,我们可以按小时找出处理类型的总数。 

CREATE TABLE test
(StartTime DATETIME NOT NULL
DEFAULT CURRENT_TIMESTAMP,
StartDate DATETIME NOT NULL
DEFAULT CONVERT(DATETIME, CONVERT(CHAR(10),CURRENT_TIMESTAMP, 110)),
StartHour INT NOT NULL
DEFAULT DATEPART(hh,CURRENT_TIMESTAMP),
TranType INT NOT NULL
CONSTRAINT ck_TranType CHECK ( TranType IN

1, -- insert
2, -- update
3, -- delete
)
DEFAULT 1
)
GO 
接下来,插入test的数据来模拟一个可能的样本。

INSERT test (StartTime, TranType) VALUES (CURRENT_TIMESTAMP, 3)
INSERT test (StartTime, TranType) VALUES (CURRENT_TIMESTAMP, 2)
INSERT test (StartTime, TranType) VALUES (CURRENT_TIMESTAMP, 3)
GO

DECLARE @hr int
SET @hr = DATEPART(hh, DATEADD(hh,-1,CURRENT_TIMESTAMP) )

INSERT test (StartTime, TranType, StartHour) _
  VALUES (DATEADD(hh,-1,CURRENT_TIMESTAMP), 3, @hr)
INSERT test (StartTime, TranType, StartHour) _
  VALUES (DATEADD(hh,-1,CURRENT_TIMESTAMP), 1, @hr)
INSERT test (StartTime, TranType, StartHour) _
  VALUES (DATEADD(hh,-1,CURRENT_TIMESTAMP), 2, @hr)
GO 

然后用一个查询来找出按日和小时的处理总数。

SELECT StartDate tran_day,
StartHour tran_hour
, CASE trantype WHEN 1 THEN 'insert'
WHEN 2 THEN 'update'
WHEN 3 THEN 'delete'
ELSE 'unknown'
END trantype,
COUNT(*) tran_total
FROM
Test
GROUP BY
StartDate,
StartHour
,trantype
ORDER BY StartDate, StartHour
COMPUTE SUM(COUNT(*)) BY StartDate, StartHour
GO
 
去掉test可以清空test表格。

DROP TABLE test
GO 
 
展开更多 50%)
分享

猜你喜欢

SQL技巧:创建用来按小时报告的查询

SQLServer
SQL技巧:创建用来按小时报告的查询

sql server查询时间技巧分享

编程语言 网络编程
sql server查询时间技巧分享

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

SQL技巧:使用SQL子选择来合并查询

SQLServer
SQL技巧:使用SQL子选择来合并查询

实现按部门月卡余额总额分组统计的SQL查询代码

SQLServer
实现按部门月卡余额总额分组统计的SQL查询代码

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

Sql联合查询

SQLServer
Sql联合查询

Sql连接查询

SQLServer
Sql连接查询

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

化解无线网络中的IP地址冲突故障

化解无线网络中的IP地址冲突故障

修复SQLSERVER2000数据库之实战经验

修复SQLSERVER2000数据库之实战经验
下拉加载更多内容 ↓