zoukankan      html  css  js  c++  java
  • sql查询技巧,按时间分段进行分组,每半小时一组统计组内记录数量

    今天拿到一个查询需求,需要统计某一天各个时间段内的记录数量。

    具体是统计某天9:00至22:00时间段,每半小时内订单的数量,最后形成的数据形式如下:
    时间段          订单数
    9:00~9:30 xx个
    9:30~10:00 xx个
    ...
     
    如果说是按每个小时来统计订单数量,这个是比较简单的,只要将订单表中的OrderTime字段中的小时取出,然后根据每个小时的值进行group by就可以了。
    select T.timehour,count(T.orderid) as number from
    (
    select o.orderid,datename(hh,o.ordertime) as timehour from orders as o 
    where o.ordertime<'2013-10-20 22:00' and o.ordertime>'2013-10-20 9:00'
    ) as T
    group by T.timehour
    order by timehour asc
     
    但是如果要实现上面的那种查询就有点麻烦了。我想到的一种实现方案是:取出每个订单的时间字段中的“小时和分钟”,将这个时间转换为距凌晨的分钟数。如:9:00转换后就是540,9:30转换后就是570。
    计算的过程是:
    1、取定一个基线值:base=540(9:00)
    2、每条条订单记录的分钟数设为:timehour
       分组编号:groupid=(timehour-base)/30
     
    这样可以将各个时间段内的时间统一到一个分组编号中去。如下:
    时间值 groupid     
    9:02     0
    9:23 0
    9:30 1
    9:31 1
    10:01 3
    ..
     
    这样一来,就把各个时间段内的时间转换成对应的某一个分组编号了,这样我们就可以对每个groupid进行分统计每个组内的订单数了。
    时间段          groupid
    9:00~9:30 0
    9:30~10:00 1
    10:00~10:30 2
    ..
     
    下面是完整的sql语句:
    select T.groupid,count(T.orderid) as number from
    (
    select o.orderid,o.ordertime,((datename(hh,o.ordertime)*60+datename(mi,o.ordertime))-540)/30 as groupid from orders as o 
    where o.ordertime<'2013-10-20 22:00' and o.ordertime>'2013-10-20 9:00'
    ) as T
    group by T.groupid
    order by groupid
     
  • 相关阅读:
    bzoj3295
    bzoj1135
    [luoguP1328] 生活大爆炸版石头剪刀布(模拟)
    考后总结
    [luoguP1970] 花匠(DP)
    [POJ3463] Sightseeing(次短路 Heap + Dijkstra)
    [luoguP2885] [USACO07NOV]电话线Telephone Wire(DP + 贪心)
    [luoguP2709] 小B的询问(莫队)
    [luoguP1972] [SDOI2009]HH的项链(莫队 || 树状数组 || 主席树)
    [luoguP2617] Dynamic Ranking(树状数组 套 主席树 + 离散化)
  • 原文地址:https://www.cnblogs.com/wang3680/p/6056882.html
Copyright © 2011-2022 走看看