一、前言
今天刚好是碰到一个报表需求,要求根据时段统计各工单的数量。这个就有点皮实了,以前都没搞过这玩意。于是研究了几下。
二、准备开始
首先一个问题,想根据时间段进行统计,这个问题先不考虑,先考虑,如果按照一小时统计呢,该怎么去做,于是就一顿操作,写出以下sql,这个基本的相信没什么难度,主要是说,怎么去单独拿到小时,这里用到“DATE_FORMAT”函数。
SELECT
DATE_FORMAT( create_order_time, '%H' ) AS h,
COUNT( 1 )
FROM
order_item
GROUP BY
DATE_FORMAT( create_order_time, '%H' )
ORDER BY
DATE_FORMAT( create_order_time, '%H' )
到这里,小时统计没问题了,那么怎么改造成符合我的需求呢,请看图片
相信聪明的人已经感觉出来的,就是其实把我们取到的小时去除以时间段的区间取整数,那么就可以得到同一区间的数据,然后这个数字在乘回去我们的区间,就可以得到上限,在加区间就是下限,最终我们得到的SQL
-- 区间数字SQL
SELECT
(FLOOR(DATE_FORMAT( create_order_time, '%H' ) / 2) * 2) AS h2,
COUNT( 1 )
FROM
order_item
GROUP BY
FLOOR(DATE_FORMAT( create_order_time, '%H' ) / 2)
ORDER BY
FLOOR(DATE_FORMAT( create_order_time, '%H' ) / 2)
-- 最终SQL
SELECT
CONCAT(
FLOOR( DATE_FORMAT( create_order_time, '%H' ) / 2 ) * 2,
'-',
FLOOR( DATE_FORMAT( create_order_time, '%H' ) / 2 ) * 2 + 2)
AS h2,
COUNT( 1 )
FROM
order_item
GROUP BY
FLOOR( DATE_FORMAT( create_order_time, '%H' ) / 2 )
ORDER BY
FLOOR( DATE_FORMAT( create_order_time, '%H' ) / 2 )
样图