使用postgres选择特定时间之间的多个数据和平均值的查询

编程入门 行业动态 更新时间:2024-10-28 17:27:24
本文介绍了使用postgres选择特定时间之间的多个数据和平均值的查询的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我在表中有来自同一数据源的两个不同日期的数据。下面给出了数据示例

此表包含将1&;2作为分支,AA、BB&;cc作为其子分支的服务器上2秒的记录数据。在原始表中,每秒以类似的方式记录数据。我想要取指定时间内每个子组的平均值,这样我就可以显示如下所示的数据。你们能帮我写一个SELECT查询吗?

推荐答案

您可以将avg_aa转换为大精度或双精度。首先从名称字段减去ID和名称,然后按ID和日期计算平均值。

-- PostgreSQL(v11)
    WITH cte_t AS (
     SELECT LEFT(name, 1) id
          , RIGHT(name, POSITION('.' IN REVERSE(name)) - 1) t_name
          , value
          , time_stamp
     FROM test
)
SELECT id
          , time_stamp :: DATE "date"
          , AVG(CASE WHEN t_name = 'aa' THEN value END) :: BIGINT "avg(aa)"
          , AVG(CASE WHEN t_name = 'bb' THEN value END) :: BIGINT "avg(bb)"
          , AVG(CASE WHEN t_name = 'cc' THEN value END) :: BIGINT "avg(cc)"
     FROM cte_t
     GROUP BY id, time_stamp :: DATE
     ORDER BY "date", id;

请从urlhttps://dbfiddle.uk/?rdbms=postgres_11&fiddle=8113ce4fd19d2865dcc5757d0e920759

查看

在平均列中使用双精度

-- PostgreSQL(v11)
WITH cte_t AS (
     SELECT LEFT(name, 1) id
          , RIGHT(name, POSITION('.' IN REVERSE(name)) - 1) t_name
          , value
          , time_stamp
     FROM test
)
SELECT id
          , time_stamp :: DATE "date"
          , AVG(CASE WHEN t_name = 'aa' THEN value END) :: DOUBLE PRECISION "avg(aa)"
          , AVG(CASE WHEN t_name = 'bb' THEN value END) :: DOUBLE PRECISION "avg(bb)"
          , AVG(CASE WHEN t_name = 'cc' THEN value END) :: DOUBLE PRECISION "avg(cc)"
     FROM cte_t
     GROUP BY id, time_stamp :: DATE
     ORDER BY "date", id;

请从urlhttps://dbfiddle.uk/?rdbms=postgres_11&fiddle=c70fe828008b13f7eb3feefc080f8038

查看

这篇关于使用postgres选择特定时间之间的多个数据和平均值的查询的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

更多推荐

[db:关键词]

本文发布于:2023-03-13 18:01:17,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/620951.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:多个   均值   和平   时间   数据

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!