首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >postgresql:如何添加列,以显示两行之间的时间差

postgresql:如何添加列,以显示两行之间的时间差
EN

Stack Overflow用户
提问于 2021-05-29 10:58:46
回答 1查看 97关注 0票数 0

我有一些带有time列的表

代码语言:javascript
复制
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

现在,我想添加另一个列,它显示时间差,另一个列,它将根据差异添加状态。

代码语言:javascript
复制
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
代码语言:javascript
复制
status = if diff >= 3 then 1 else 0 

我该怎么做呢。我必须得到过去七天的数据,然后才能得到最后的表格。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-05-29 11:06:31

使用LAG

代码语言:javascript
复制
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;
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67750544

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档