我有一张记录电表值的表格
表格如下所示
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直接解决吗?我尝试了一些带有光标的样本,但没有真正找到解决方案。
答案 0 :(得分:2)
SQL表本质上是无序的,因此没有“先前”记录。这个问题没有意义,除非你有一个指定排序的列。
我认为问题是created_at
不是这样的专栏,而是RecordId
。如果是这样,您可以使用lag()
功能:
select created_at, value,
(value - lag(value) over (order by recordId)) as delta
from metervalues
如果你没有这样的id,那么你需要找到一种方法来指定值的排序。
答案 1 :(得分:1)
SELECT
created_at,
"value",
"value" - lag("value", 1, 0) over(order by created_at) as consumption
FROM metervalues
ORDER BY created_at
编辑:在as
之前遗失consumption
- 现已更正