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;

按天分组统计

在这里插入图片描述
相关推荐
Trouvaille ~6 分钟前
【Redis篇】Redis 主从复制:数据同步的原理与实现
数据库·redis·缓存·中间件·高可用·主从复制·后端开发
真实的菜24 分钟前
Redis 从入门到精通(五):哨兵模式(Sentinel)—— 自动故障转移的完整原理与实战
数据库·redis·sentinel
唔6640 分钟前
(二)补充完整的数据库、中间件、MQTT、JAR后台和Web前端的部署脚本,全部一键自动化。
数据库·中间件·jar
六月雨滴41 分钟前
Oracle 内存优化
数据库·oracle
学代码的真由酱1 小时前
MySQL数据库进阶-数据库设计实践-Java
数据库·mysql·数据库设计
遇事不決洛必達1 小时前
【数据库系列】本地映射云服务器Mysql的方法
服务器·数据库·mysql·定时任务
海鸥-w1 小时前
用python (fastapi)做项目第一天创建项目结构,数据建表,ORM配置安装,写第一个接口
数据库·python·fastapi
zfoo-framework2 小时前
通过redis-cli+lua脚本查询redis数据
数据库·redis·lua
牛栓柱2 小时前
【后端实战】用 Supabase + React/TS 零成本构建高并发 Multi-Agent 服务
前端·数据库·人工智能·后端·react.js·前端框架
yuezhilangniao2 小时前
xtr备份prepare到底变化了啥
mysql