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 如何用stata画出文献中常见的安慰剂检验图
  • ¥15 c语言链表结构体数据插入
  • ¥40 使用MATLAB解答线性代数问题
  • ¥15 COCOS的问题COCOS的问题
  • ¥15 FPGA-SRIO初始化失败
  • ¥15 MapReduce实现倒排索引失败
  • ¥15 ZABBIX6.0L连接数据库报错,如何解决?(操作系统-centos)
  • ¥15 找一位技术过硬的游戏pj程序员
  • ¥15 matlab生成电测深三层曲线模型代码
  • ¥50 随机森林与房贷信用风险模型