MySQL按小时分组统计日志记录数量

业务场景

MySQL按小时分组统计日志记录数量。最近需要统计一些日志流水,统计出打卡的高峰期,所以需要对日志流水按小时进行分组统计,统计出每半小时或者每小时内的打卡次数

按小时统计

这里使用DATE_FORMAT函数,然后再根据createTime进行分组,就可以统计每个小时内的打卡次数
登录后复制

plain 复制代码
SELECT
	device_id,
	DATE_FORMAT(
		create_time,
		'%Y-%m-%d %H:00:00'
	) AS createTime,
	count(*) AS num
FROM
	t_user_atten_record
WHERE
	com_id = 1111699
GROUP BY
	device_id, createTime
ORDER BY
	device_id, createTime;

每小时分组统计结果:

在这里插入图片描述

每半小时统计

要统计每半小时内的打卡次数,可以使用,MINUTE先获取对应日期的分钟,半小时就是30分钟,floor(MINUTE(create_time) / 30)是进行四舍五入计算,再乘以30floor(MINUTE(create_time) / 30) * 30就是按30分钟归类为一组,同理再进行group by分组统计
登录后复制

plain 复制代码
SELECT
	device_id,
	DATE_FORMAT(
		concat(
			date(create_time),
			' ',
			HOUR (create_time),
			':',
			floor(MINUTE(create_time) / 30) * 30
		),
		'%Y-%m-%d %H:%i'
	) AS createTime,
	count(*) AS num
FROM
	t_user_atten_record
WHERE
	com_id = 1111699

GROUP BY
	device_id, createTime 
ORDER BY
	device_id, createTime;

每半小时分组统计结果:

在这里插入图片描述

基于此,还可以继续拓展,按每N分钟、每分钟、每天进行分组统计

每N分钟统计

前面是按照半小时(30分钟),依此类推,可以按n分钟进行分组统计,统计n分钟内的打卡次数,比如统计每10分钟内的打卡次数
登录后复制

plain 复制代码
SELECT
	device_id,
	DATE_FORMAT(
		concat(
			date(create_time),
			' ',
			HOUR (create_time),
			':',
			floor(MINUTE(create_time) / 10) * 10
		),
		'%Y-%m-%d %H:%i'
	) AS createTime,
	count(*) AS num
FROM
	t_user_atten_record
WHERE
	com_id = 1111699

GROUP BY
	device_id, createTime 
ORDER BY
	device_id, createTime;

统计每10分钟内的打卡次数

在这里插入图片描述

按分钟统计

如果要按分钟进行分组,统计每分钟内的打卡次数
登录后复制

plain 复制代码
SELECT
	device_id,
	DATE_FORMAT(
		create_time,
		'%Y-%m-%d %H:%i:00'
	) AS createTime,
	count(*) AS num
FROM
	t_user_atten_record
WHERE
	com_id = 1111699
GROUP BY
	device_id, createTime
ORDER BY
	device_id, createTime;

按分钟进行分组统计:

在这里插入图片描述

按日期统计

按照日期进行分组,统计每天的打卡次数:
登录后复制

plain 复制代码
SELECT
	device_id,
	DATE(
		create_time
	) AS createTime,
	count(*) AS num
FROM
	t_user_atten_record
WHERE
	com_id = 1111699
GROUP BY
	device_id, createTime
ORDER BY
	device_id, createTime;

按天分组统计

在这里插入图片描述
相关推荐
笃行35010 小时前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行35010 小时前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行35010 小时前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库
元Y亨H10 小时前
技术笔记:MySQL 字符集排序规则与大小写敏感性问题解决方案
mysql
SelectDB1 天前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台
大数据·数据库·aigc
这个DBA有点耶1 天前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构
掉头发的王富贵1 天前
【StarRocks】极限十分钟入门StarRocks
数据库·sql·mysql
Nturmoils1 天前
WHERE 条件别凭习惯写,常用查询先跑一遍
数据库
SamDeepThinking2 天前
一条UPDATE语句在MySQL 8.0中到底加了几把锁?
后端·mysql·程序员