mysql 监控开始时间,结束时间,平均取n个时间点

需求

最近1小时 1分钟 60个点

最近3小时 5分钟 36个点

最近6小时 10分钟 36个点

最近12小时 20分钟 36个点

最近1天 1小时 24个点

最近3天 3小时 24个点

最近1周 6小时 28个点

如果你的递归查询支持递归CTE(如MySQL 8.0+),可以使用递归查询来生成平均分布的时间点。下面是一个示例,假设开始时间为 start_time,结束时间为 end_time,要取n个时间点:

sql 复制代码
WITH RECURSIVE TimePoints AS (
    SELECT TIMESTAMPADD(SECOND, 0, start_time) AS time_point, 1 AS point_number
    UNION ALL
    SELECT TIMESTAMPADD(SECOND, (UNIX_TIMESTAMP(end_time) - UNIX_TIMESTAMP(start_time)) / (n - 1) * point_number, start_time), point_number + 1
    FROM TimePoints
    WHERE point_number < n
)
SELECT time_point
FROM TimePoints;

解释:

WITH RECURSIVE TimePoints AS: 这部分定义了一个递归CTE,用于生成时间点序列。

SELECT TIMESTAMPADD(SECOND, 0, start_time) AS time_point, 1 AS point_number: 这是递归的起始部分,设置第一个时间点和计数器。

SELECT TIMESTAMPADD(SECOND, (UNIX_TIMESTAMP(end_time) - UNIX_TIMESTAMP(start_time)) / (n - 1) * point_number, start_time), point_number + 1: 这是递归部分,通过计算时间段的秒数差除以(n-1)来计算每个时间点的间隔。

WHERE point_number < n: 这个条件确保递归停止在生成n个时间点之后。

最后的 SELECT time_point FROM TimePoints: 返回生成的时间点序列。

例子:

sql 复制代码
WITH RECURSIVE TimePoints AS (
    SELECT TIMESTAMPADD(SECOND, 0, '2024-08-08 18:30:00') AS time_point, 1 AS point_number
    UNION ALL
    SELECT TIMESTAMPADD(SECOND, (UNIX_TIMESTAMP('2024-08-08 21:30:00') - UNIX_TIMESTAMP('2024-08-08 18:30:00')) / (6 - 1) * point_number, '2024-08-08 18:30:00'), point_number + 1
    FROM TimePoints
    WHERE point_number < 6
)
SELECT time_point,(SELECT name
FROM op_custom_config_tb
ORDER BY ABS(TIMESTAMPDIFF(SECOND, update_time, time_point))
LIMIT 1) aaa
FROM TimePoints;
相关推荐
妖灵翎幺4 分钟前
Java应届生求职八股(2)---Mysql篇
数据库·mysql
HMBBLOVEPDX7 分钟前
MySQL的事务日志:
数据库·mysql
weixin_419658312 小时前
MySQL数据库备份与恢复
数据库·mysql
wml000002 小时前
CentOS启动两个MySQL实例
mysql·centos·3406
专注API从业者4 小时前
基于 Flink 的淘宝实时数据管道设计:商品详情流式处理与异构存储
大数据·前端·数据库·数据挖掘·flink
小猿姐5 小时前
KubeBlocks for Milvus 揭秘
数据库·云原生
AI 嗯啦5 小时前
SQL详细语法教程(四)约束和多表查询
数据库·人工智能·sql
杜子不疼.5 小时前
《Python学习之文件操作:从入门到精通》
数据库·python·学习
TDengine (老段)6 小时前
TDengine IDMP 高级功能(4. 元素引用)
大数据·数据库·人工智能·物联网·数据分析·时序数据库·tdengine
DashVector6 小时前
如何通过Java SDK分组检索Doc
java·数据库·面试