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

  • 相关阅读:
    Java连接数据库 #02# JDBC经典套路
    Eloquent JavaScript #03# functions
    Java笔记 #04# 类的初始化顺序补充
    Java笔记 #03# HtmlUnit爬虫
    Google's Machine Learning Crash Course #04# First Steps with TensorFlow
    IntelliJ IDEA. Debug模式
    python实用笔记,加快编程速度,lamdba,三元运算,open.
    开源项目管理平台*redmine*的架设
    MYSQL双主故障解决实例。
    LVS-DR工作原理
  • 原文地址:https://www.cnblogs.com/gccbuaa/p/6848922.html
Copyright © 2011-2022 走看看