文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

mysql查询过去24小时内每小时数据量的方法(精确到分钟)

2023-03-06 08:04

关注

项目场景:

获取过去24小时每小时数据量(没有为0)

问题描述

时间段要求精确到分钟,即:10.33 ~ 11.33,11.33~12.33……

解决方案:

第一步:获取24个时间点:

1.使用数据量一定大于24的表(可以是数据库自带的,也可以是自己项目的)

SET @i=-1;
SELECT DATE_SUB( NOW(),INTERVAL ( (@i:=@i+1) ) HOUR ) AS 'time' 
FROM  mysql.help_category 
WHERE @i<23

2.建一个24个数据量的表

SET @i=-1;
SELECT DATE_SUB( NOW(), INTERVAL((@i:=@i+1)) HOUR) AS 'time' 
FROM 
(SELECT *  FROM 
	(SELECT '1' AS a UNION SELECT '2' UNION SELECT '3' UNION SELECT '4'   ) AS a
 	JOIN 
	( SELECT  '1' UNION  '2' UNION SELECT '3' UNION SELECT '4' UNION SELECT '5' UNION SELECT '6' ) AS b
 ) AS c 
 WHERE @i<23

NOW() 获取当前时间,也是最后一个时间节点

DATE_SUB() 函数从日期减去指定的时间间隔

INTERVAL 关键字可以用于计算时间间隔

HOUR 间隔类型(小时)

使用格式:DATE_SUB(date,INTERVAL expr type)

获取的时间点如下:

查询结果

第二步:将要查询的表的时间向右偏移至整点,并查询时段内数据量:

将10.33 ~ 11.33之间的数据的时间,显示为:11.00~12.00

这样小时为11的数据就是原数据库中10.33 ~ 11.33的数据,方便之后的查询

SELECT DATE_FORMAT(DATE_SUB( create_time,INTERVAL MINUTE(NOW())-60 MINUTE ) ,'%Y-%m-%d %H') AS date, count(*) AS num 
FROM mytable GROUP BY date

结果如下:

查询结果

第二步:多表连接查询:

SET  @i=-1;
SELECT t.time, ifnull(num,0) AS count FROM 
	(SELECT DATE_SUB( NOW(),INTERVAL ( (@i:=@i+1) ) HOUR ) AS 'time' 
	FROM  mysql.help_category where @i<23) 
AS t 
LEFT JOIN 
	(SELECT DATE_FORMAT(DATE_SUB( create_time,INTERVAL MINUTE(NOW())-60 MINUTE ) ,'%Y-%m-%d %H') AS date, count(*) AS num 
	FROM mytable GROUP BY date ) 
AS sa 
ON sa.date = DATE_FORMAT( t.time,'%Y-%m-%d %H')  GROUP BY t.time

结果如下:

查询结果

count表示的是时间节点前一个小时的数据量,不包含此节点,如果要包含此节点,可以将上面的60改成59

附:Mysql 查询每小时数据的总数

1.通过sql查询每小时的数据总数,没有先不管

 SELECT
      hour(表_时间)  hour,
      count(表_id) count
    FROM 表_name
    //限制年月日(current_date  2022-03-05)
    WHERE  date_format(表_时间, '%Y-%m-%d') = current_date//格式化时间
    GROUP BY date_format(表_时间, '%Y%m%d-%H'), hour//按每小时分组

2.通过map,数组工具把没有数据的小时置为0;

总结

到此这篇关于mysql查询过去24小时内每小时数据量的文章就介绍到这了,更多相关mysql查询每小时数据量内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯