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 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)