SQL游标操作每隔5分钟时间段数据统计信息

Tb_People 表信息:

         id     uname    era     amount    plushtime          
1000031    张亮    中年    100000    201404050908  
1000032    张亮    中年    100000    201404050913   
1000033    天天    年轻    233233    201404050918   
1000034    天天    年轻    233233    201404050923   
1000035    kimi    年轻    455631    201404050933   
1000036    kimi    年轻    455631    201404050938   

--分析出每5分钟内有多少人乘车
  --时间转化秒不用转化 初始刷卡时间值是20140404090806
   UPDATE [Tb_People] SET shuacardtime=SUBSTRING(plushtime,1,4)+'-'+SUBSTRING(plushtime,5,2)+'-'+SUBSTRING(plushtime,7,2)+' '+SUBSTRING(plushtime,9,2)+':'+SUBSTRING(plushtime,11,2)

结果为:

       id      uname   era    amount    plushtime           shuacardtime
1000031    张亮    中年    100000    201404050908    2014-04-05 09:08
1000032    张亮    中年    100000    201404050913    2014-04-05 09:13
1000033    天天    年轻    233233    201404050918    2014-04-05 09:18
1000034    天天    年轻    233233    201404050923    2014-04-05 09:23
1000035    kimi    年轻    455631    201404050933    2014-04-05 09:33
1000036    kimi    年轻    455631    201404050938    2014-04-05 09:38

--构造区间段
declare @dayBegin datetime,@dayEnd datetime
declare @table table(StartTime datetime,EndTime datetime)
set @dayBegin = '2014-04-05 6:00'
set @dayEnd = '2014-04-06 0:00'
while @dayBegin <=@dayEnd
 begin
 insert @table select @dayBegin,dateadd(mi,5,@dayBegin)  --每5分钟一个间隔
 set @dayBegin=dateadd(mi,5,@dayBegin)
 end
select * from @table -- 执行后数据如下

 StartTime                              EndTime
2014-04-05 06:00:00.000    2014-04-05 06:05:00.000
2014-04-05 06:05:00.000    2014-04-05 06:10:00.000
2014-04-05 06:10:00.000    2014-04-05 06:15:00.000
2014-04-05 06:15:00.000    2014-04-05 06:20:00.000
2014-04-05 06:20:00.000    2014-04-05 06:25:00.000

--区间段分好了,就可以想到每取出一个时间段,然后在乘车时间记录表里查询有多少条记录在该段时间内就行了,可以考虑用游标。
declare s cursor  --declare 创建游标
static
for select StartTime,EndTime from @table

--定义变量
declare @StartTime datetime,@EndTime datetime
declare @TempTable table(StartTime datetime,EndTime datetime,Number int)

open s  --打开游标
fetch next from s into @StartTime,@EndTime --提取上次提取行的下一行
while(@@fetch_status = 0)
begin
  insert @TempTable select isnull(max(@StartTime),@StartTime),isnull(max(@EndTime),@EndTime), count(*) from Tb_People where shuacardtime > @StartTime and shuacardtime <=@EndTime 
--这里就不能用between and了,不然分隔的时间点上车的人数会在相邻的两个区间段重复计数,另外第一班车的上车时间等于@StartTime 没有计进去,这里不影响总体分析,当然可以做个标记,读一个区间段时用between...and...就可以了
   fetch next from s into @StartTime,@EndTime
end
close s  --关闭游标
deallocate s  --删除游标,释放资源
select * from @TempTable

 执行结果如下:

StartTime                                EndTime                      Number
2014-04-05 09:05:00.000    2014-04-05 09:10:00.000    1
2014-04-05 09:10:00.000    2014-04-05 09:15:00.000    1
2014-04-05 09:15:00.000    2014-04-05 09:20:00.000    1
2014-04-05 09:20:00.000    2014-04-05 09:25:00.000    1
2014-04-05 09:25:00.000    2014-04-05 09:30:00.000    0
2014-04-05 09:30:00.000    2014-04-05 09:35:00.000    1

 

posted @ 2014-04-05 23:54  蜜雪粮液  阅读(3029)  评论(1编辑  收藏  举报