gpt4 book ai didi

sql - Postgres 更新前一行

转载 作者:行者123 更新时间:2023-11-29 12:46:42 26 4
gpt4 key购买 nike

我有一个记录电表值的表

表格是这样的

SELECT created_at, value, delta 
FROM metervalues
ORDER BY created_at

2013-05-28 07:59:00 | 752105,6 | null
2013-05-28 08:14:00 | 752156,0 | null
2013-05-28 08:29:00 | 752207,2 | null
2013-05-28 08:44:00 | 752259,2 | null
2013-05-28 08:59:00 | 752312,8 | null
2013-05-28 09:14:00 | 752366,4 | null
2013-05-28 09:29:00 | 752417,2 | null

现在我要计算消耗所以

delta(current record) = value(current record) - value(previous record)

记录可能会在稍后添加,因此记录 ID 不一定遵循“created_at”顺序。

目前我正在使用 ruby​​ 脚本加载数据,然后循环并更新记录。这很慢。

这可以通过SQL直接解决吗?我用游标尝试了一些示例,但没有真正找到解决方案。

最佳答案

SQL 表本质上是无序的,因此不存在“先前”的记录。这个问题没有意义,除非您有一列指定了顺序。

我认为问题是说 created_at 不是这样的列,但是 RecordId 是。如果是这样,您可以使用 lag() 函数:

select created_at, value,
(value - lag(value) over (order by recordId)) as delta
from metervalues

如果您没有这样的 id,那么您需要找到一种方法来指定值的顺序。

关于sql - Postgres 更新前一行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17092232/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com