如何解决postgresql:如何添加显示两行之间时间差的列
我有一些包含 time
列的表格
id | time
----|-------------------
1 | 2021-2-2 10:21:00
2 | 2021-2-2 10:24:00
3 | 2021-2-2 10:27:00
4 | 2021-2-2 10:29:00
id | time | diff | status
----|----------------------------------
1 | 2021-2-2 10:21:00 | None | None
2 | 2021-2-2 10:24:00 | 3:00 | 1
3 | 2021-2-2 10:26:00 | 2:00 | 0
4 | 2021-2-2 10:29:00 | 3:00 | 1
status = if diff >= 3 then 1 else 0
我该怎么做。我必须得到过去 7 天的数据,然后才能得到这张决赛桌。
解决方法
使用LAG
:
SELECT id,time,EXTRACT(EPOCH FROM time - LAG(time) OVER (ORDER BY time)) / 60 AS diff,(EXTRACT(EPOCH FROM time - LAG(time) OVER (ORDER BY time)) / 60 >= 3)::int AS status
FROM yourTable
ORDER BY time;
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。