zoukankan      html  css  js  c++  java
  • SQLServer时间分段查询

    统计连续时间段数据

    if OBJECT_ID(N'Test',N'U') is not null
    	drop table Test
    go 
    
    create table Test(
    	pscode decimal(15),
    	outputcode int,
    	monitortime datetime
    )
    
    insert into Test
    select 4100000406,1,convert(datetime,'2015-04-01 00:00') union all
    select 4100000406,1,convert(datetime,'2015-04-01 01:00') union all
    select 4100000406,1,convert(datetime,'2015-04-01 02:00') union all
    select 4100000406,1,convert(datetime,'2015-04-01 03:00') union all
    select 4100000406,1,convert(datetime,'2015-04-01 04:00') union all
    select 4100000406,1,convert(datetime,'2015-04-01 05:00') union all
    select 4100000406,1,convert(datetime,'2015-04-01 06:00') union all
    select 4100000406,1,convert(datetime,'2015-04-01 07:00') union all
    select 4100000406,1,convert(datetime,'2015-04-01 08:00') union all
    select 4100000406,1,convert(datetime,'2015-04-01 09:00') union all
    select 4100000406,1,convert(datetime,'2015-04-01 10:00') union all
    select 4100000406,1,convert(datetime,'2015-04-01 11:00') union all
    select 4100000406,1,convert(datetime,'2015-04-01 13:00') union all
    select 4100000406,1,convert(datetime,'2015-04-01 14:00') union all
    select 4100000406,1,convert(datetime,'2015-04-01 15:00') union all
    select 4100000406,1,convert(datetime,'2015-04-01 16:00') union all
    select 4100000406,1,convert(datetime,'2015-04-01 17:00') union all
    select 4100000406,1,convert(datetime,'2015-04-01 18:00') union all
    select 4100000406,1,convert(datetime,'2015-04-01 19:00') union all
    select 4100000406,1,convert(datetime,'2015-04-01 20:00') union all
    select 4100000406,1,convert(datetime,'2015-04-01 22:00') union all
    select 4100000406,1,convert(datetime,'2015-04-01 23:00') union all
    select 4100000405,2,convert(datetime,'2015-04-01 01:00') union all
    select 4100000405,2,convert(datetime,'2015-04-01 02:00') union all
    select 4100000405,2,convert(datetime,'2015-04-01 03:00') union all
    select 4100000405,2,convert(datetime,'2015-04-01 04:00') union all
    select 4100000405,2,convert(datetime,'2015-04-01 05:00') union all
    select 4100000405,2,convert(datetime,'2015-04-01 06:00') union all
    select 4100000405,2,convert(datetime,'2015-04-01 07:00') union all
    select 4100000405,2,convert(datetime,'2015-04-01 08:00') union all
    select 4100000405,2,convert(datetime,'2015-04-01 09:00') union all
    select 4100000405,2,convert(datetime,'2015-04-01 11:00') union all
    select 4100000405,2,convert(datetime,'2015-04-01 12:00') union all
    select 4100000405,2,convert(datetime,'2015-04-01 13:00') union all
    select 4100000405,2,convert(datetime,'2015-04-01 14:00') union all
    select 4100000405,2,convert(datetime,'2015-04-01 15:00') union all
    select 4100000405,2,convert(datetime,'2015-04-01 16:00') union all
    select 4100000405,2,convert(datetime,'2015-04-01 17:00') union all
    select 4100000405,2,convert(datetime,'2015-04-01 18:00') union all
    select 4100000402,1,convert(datetime,'2015-04-01 00:00') union all
    select 4100000402,1,convert(datetime,'2015-04-01 01:00') union all
    select 4100000402,1,convert(datetime,'2015-04-01 02:00') union all
    select 4100000402,1,convert(datetime,'2015-04-01 03:00') union all
    select 4100000402,1,convert(datetime,'2015-04-01 04:00') union all
    select 4100000402,1,convert(datetime,'2015-04-01 05:00') union all
    select 4100000402,1,convert(datetime,'2015-04-01 06:00') union all
    select 4100000402,1,convert(datetime,'2015-04-01 07:00') union all
    select 4100000402,1,convert(datetime,'2015-04-01 08:00') union all
    select 4100000402,1,convert(datetime,'2015-04-01 09:00') union all
    select 4100000402,1,convert(datetime,'2015-04-01 11:00') union all
    select 4100000402,1,convert(datetime,'2015-04-01 12:00') union all
    select 4100000402,1,convert(datetime,'2015-04-01 13:00') union all
    select 4100000402,1,convert(datetime,'2015-04-01 14:00') union all
    select 4100000402,1,convert(datetime,'2015-04-01 15:00') union all
    select 4100000402,1,convert(datetime,'2015-04-01 16:00') union all
    select 4100000402,1,convert(datetime,'2015-04-01 17:00') union all
    select 4100000402,1,convert(datetime,'2015-04-01 18:00') union all
    select 4100000402,1,convert(datetime,'2015-04-01 19:00') union all
    select 4100000402,1,convert(datetime,'2015-04-01 20:00') union all
    select 4100000402,1,convert(datetime,'2015-04-01 22:00') union all
    select 4100000402,1,convert(datetime,'2015-04-01 23:00')
    
    
    select pscode,outputcode,
    	   convert(varchar(16),MIN(monitortime),120)+'~'+convert(varchar(16),MAX(monitortime),120) fw,
           COUNT(1) num
      from (select x.pscode,x.outputcode,x.monitortime,dateadd(HOUR,-x.orderby,x.monitortime) diff
    		  from (select pscode,outputcode,monitortime,
    					   ROW_NUMBER() over(partition by pscode,outputcode order by pscode,outputcode,monitortime) orderby 
    				  from Test) x)y 
     group by y.pscode,y.outputcode,y.diff

  • 相关阅读:
    线段树模板题 contest 线段树 T5
    Guide AHOI2017 洛谷P3720
    静态RMQ模板题 contest 静态RMQ T2
    树状数组模板题 P1904
    AC自动机模板题 P2017
    高精度排序模板题 P1110
    Trie树模板题 P2016
    树状数组套权值线段树
    爬山 启发式合并 / STL
    [POI2011]ROT-Tree Rotations 线段树合并|主席树 / 逆序对
  • 原文地址:https://www.cnblogs.com/gccbuaa/p/6848922.html
Copyright © 2011-2022 走看看