在MySQL中按时间间隔聚合数据

cde*_*ker 7 mysql group-by aggregate

基本上我想要的是根据时间跨度在表中聚合一些值.

我所做的是,我每隔15分钟拍摄一个系统的快照,我希望能够在很长一段时间内绘制一些图表.如果显示太多的点(除了渲染速度非常慢)之外,图形会变得非常混乱,我想通过对多个点进行平均来将多个点聚合到一个点来减少点数.

为此,我必须能够通过我可以定义的桶(每天,每周,每月,每年......)进行分组,但到目前为止,我的所有实验都没有运气.

有什么技巧可以申请吗?

cmr*_*rgo 10

我有一个类似的问题:整理 - 统计 - 进入时间 - 块并得到了很好的回答.从本质上讲,答案是:

也许你可以使用DATE_FORMAT()函数和分组.这是一个例子,希望您能够适应您的确切需求.

SELECT
    DATE_FORMAT( time, "%H:%i" ),
    SUM( bytesIn ),
    SUM( bytesOut )
FROM
    stats
WHERE
    time BETWEEN <start> AND <end>
GROUP BY
    DATE_FORMAT( time, "%H:%i" )
Run Code Online (Sandbox Code Playgroud)

如果您的时间窗口超过一天并且您使用示例格式,则不同日期的数据将汇总到"每小时"桶中.如果原始数据不是完全按小时计算,则可以使用"%H:00"将其平滑.

感谢马丁克莱顿为他提供的答案.