mysql查询连续时间段内的数据量的3种方法

1、使用DATE_FORMAT()函数
用于以不同的格式显示日期/时间数据。

DATE_FORMAT(ACTUAL_ARRIVE_TIME,'%Y/%m/%d %H:%i:%s')

在这里插入图片描述
用DATE_FORMAT()函数查询每小时的订单量:

SELECT
	DATE_FORMAT(CREATE_TIME, '%Y-%m-%d %H') MIN5,
	COUNT(0)
FROM
	ORDER_TABLE
WHERE
	CREATE_TIME BETWEEN '2020-12-01 00:00:00'
AND '2020-12-01 12:00:00'
GROUP BY
	MIN5;

执行结果:
在这里插入图片描述用DATE_FORMAT()函数查询每天的订单量:

只需要改DATE_FORMAT()函数即可
SELECT
	DATE_FORMAT(CREATE_TIME, '%Y-%m-%d') MIN5,
	COUNT(0)
FROM
	ORDER_TABLE
WHERE
	CREATE_TIME BETWEEN '2020-12-01 00:00:00'
AND '2020-12-01 12:00:00'
GROUP BY
	MIN5;

执行结果:
在这里插入图片描述

SUBDATE()函数:指定日期减去指定的时间间隔。

语法:DATE_SUB(date,INTERVAL expr type)
date 参数是合法的日期表达式。expr 参数是您希望添加的时间间隔。
例子:SUBDATE(NOW(),1)

2、使用SUBSTR()函数
MySQL 中获取子串函数 SUBSTRING(s,n,len) 带有 len 参数的格式,从字符串 s 返回一个长度同 len 字符相同的子字符串,起始于位置 n。也可能对 n 使用一个负值。假若这样,则子字符串的位置起始于字符串结尾的第 n 个字符,即倒数第 n 个字符,而不是字符串的开头位置。

SELECT SUBSTR('abcdefg',2,3);-- bcd
SELECT SUBSTR('abcdefg',-5,3);-- cde
SELECT SUBSTR(NOW(),1,10);-- 2020-12-15

可以对日期进行剪切,可以用SUBSTR()函数查询固定时间间隔内的数据量。
例如查每天的订单量:

SELECT
	SUBSTR(CREATE_TIME, 1, 10) AS "日期",
	count(0) AS "数量"
FROM
	ORDER_TABLE
WHERE
	CREATE_TIME BETWEEN '2020-12-01 00:00:00'
AND '2020-12-05 00:00:00'
GROUP BY
	SUBSTR(CREATE_TIME, 1, 10);

查询结果:
在这里插入图片描述也可以查每个小时的订单量,截取时间到小时:

SELECT
	SUBSTR(CREATE_TIME, 1, 13) AS "时间",
	count(0) AS "数量"
FROM
	ORDER_TABLE
WHERE
	CREATE_TIME BETWEEN '2020-12-01 00:00:00'
AND '2020-12-01 12:00:00'
GROUP BY
	SUBSTR(CREATE_TIME, 1, 13);

执行结果:
在这里插入图片描述如果截取的时间到分钟,则可以查没分钟的订单量。

查询存在相同订单号的订单:

SELECT
	OEDER_NO,
	COUNT(*)
FROM
	ORDER_TABLE
WHERE
	CREATE_TIME > '2020-12-01 00:00:00'
AND CREATE_TIME < '2020-12-02 00:00:00'
GROUP BY
	OEDER_NO
HAVING
	COUNT(*) > 1

3、查询每十分钟的订单量

SELECT 
DATE_FORMAT(ADDDATE(DATE_FORMAT(concat(date(CREATE_TIME),' ',HOUR(CREATE_TIME),':',(floor((MINUTE(CREATE_TIME) / 10)) * 10)),'%Y-%m-%d %H:%i'),INTERVAL 10 MINUTE),'%Y-%m-%d %H:%i:%s') as time, 
COUNT(*) 
FROM ORDER_TABLE
WHERE '2020-12-14 12:00:00' > CREATE_TIME AND '2020-12-14 08:00:00' <= CREATE_TIME
GROUP BY time ORDER BY time DESC;

执行结果:
在这里插入图片描述
若查询每20分钟,30分钟的数据量,可以将上边的10改成10或者30即可。

  • 2
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值