【问题标题】:Get previous days' value in column in postgres在 postgres 的列中获取前几天的值
【发布时间】:2020-03-03 03:01:01
【问题描述】:

我有一个问题。

我有一个 sql 命令,它使用窗口函数获取每天的移动平均值。

        BEGIN;
            DROP TABLE IF EXISTS vol_stats;
            SELECT pk as fk, 
                   avg(CAST(volume as FLOAT)) over (partition by account_id order by "endts") as average,
            INTO vol_stats
            from volume_temp
            order by account_id, "endts";
        COMMIT;

我想再获得一个价值,那就是前几天的价值。

数据结构如下所示。

acccount_id | value | timestamp 
-------------------------------
a12         | 122   | jan 1
a13         | 133   | jan 1
a14         | 443   | jan 1
a12         | 251   | jan 2
a13         | 122   | jan 2
a14         | 331   | jan 2
a12         | 412   | jan 3
a13         | 323   | jan 3
a14         | 432   | jan 3

我们正在计算这个

acccount_id | value | timestamp | Average
-----------------------------------------
a12         |  122  | jan 1     | 122
a13         |  133  | jan 1     | 133
a14         |  443  | jan 1     | 443
a12         |  251  | jan 2     | 188.5
a13         |  122  | jan 2     | 222.5
a14         |  331  | jan 2     | 387
a12         |  412  | jan 3     | 261.6
a13         |  323  | jan 3     | 192.6
a14         |  432  | jan 3     | 402

同时获取前几天的价值会有所帮助。像这样。

acccount_id | value | timestamp | Average | previous
-----------------------------------------
a12         |  122  | jan 1     | 122     | null
a13         |  133  | jan 1     | 133     | null
a14         |  443  | jan 1     | 443     | null
a12         |  251  | jan 2     | 188.5   | 122
a13         |  122  | jan 2     | 222.5   | 133
a14         |  331  | jan 2     | 387     | 443
a12         |  412  | jan 3     | 261.6   | 251
a13         |  323  | jan 3     | 192.6   | 122
a14         |  432  | jan 3     | 402     | 331

【问题讨论】:

  • 与您的问题无关,但是:Postgres 9.2 是no longer supported,您应该尽快计划升级。

标签: postgresql psql postgresql-9.2


【解决方案1】:

只需在SELECT 列表中添加另一列:

lag(volume) OVER (PARTITION BY account_id ORDER BY endts)

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2014-04-29
    • 2016-01-20
    • 1970-01-01
    • 2020-04-12
    • 1970-01-01
    • 2021-03-24
    • 1970-01-01
    相关资源
    最近更新 更多