hxs4128 2013-10-23 02:55 采纳率: 0%
浏览 932

SQL 如何显示每3小时一条记录?

表中有时间列TIME_2800和其他列名,我可以显示每小时一条数据(select hour(TIME_2800) as hour2800,...),但我不知道怎么显示每三小时一条记录.请教各位大神指教!灰常感谢!

  • 写回答

1条回答 默认 最新

  • 秋风お亦冷 2023-07-27 17:16
    关注

    要显示每三小时一条记录,您可以使用 MySQL 中的 DATE_FORMAT 函数来格式化时间列 TIME_2800 并将其舍入到最近的三小时。然后,您可以使用 GROUP BY 子句将结果按小时分组,并使用聚合函数(如 MAX 或 MIN)获取每个小时的一行数据。

    以下是一个示例查询,显示每三小时一个记录:

    SELECT DATE_FORMAT(TIME_2800, '%Y-%m-%d %H:00:00') AS hour2800, MAX(col1) AS max_col1, MIN(col2) AS min_col2, AVG(col3) AS avg_col3
    FROM your_table
    GROUP BY HOUR(TIME_2800) DIV 3
    

    在上面的查询中,我们使用 DATE_FORMAT 函数将时间列 TIME_2800 格式化为按小时舍入到最近的三小时。然后,我们使用 GROUP BY 子句按三小时分组,并使用聚合函数 MAX、MIN 和 AVG 获取每个三小时的数据。

    请注意,上述查询中的聚合函数可以根据您的需求进行更改,以获取您所需的聚合值。同时,如果您的数据表中有其他需要显示的列,您可以将它们添加到 SELECT 子句中并按需要聚合它们。

    评论

报告相同问题?

悬赏问题

  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器