别问、在的 2022-07-15 20:58 采纳率: 100%
浏览 200
已结题

pgsql,用一个时间字段排序后衍生出另一个字段

如时间字段1,从2022-07-13 00:00:00到2022-07-13 02:00:00有10行数据升序排序,用这个字段计算得到字段2:字段2的第一行直接等于字段1的第一行,第二行开始用计算得到:字段1的第二行减去字段2的第一行大于五秒,则选择字段1第二行,否则选字段2第一行保存至字段2第二行,以此类推,直到字段1第n行和字段2第n-1行计算完毕

  • 写回答

5条回答 默认 最新

  • 坤坤不爱吃鱼 2022-07-16 16:56
    关注

    使用窗口函数dt,lead(dt) over(order by dt),这个是下移,然后在进行判断,为空去dt的值

    dt日期默认升序
    2022-07-13 00:00:00
    2022-07-13 00:00:06
    2022-07-13 00:00:11
    2022-07-13 00:00:14
    2022-07-13 00:04:00
    2022-07-13 00:04:05
    2022-07-13 00:04:07
    2022-07-13 00:04:32
    2022-07-13 01:33:07
    2022-07-13 01:33:10
    with  TMP as 
    (select dt,lead(dt,1) over(order by dt) tmp_dt from tabe1)
    
    select dt,case when tmp_dt is null
                    then  dt 
                    when EXTRACT(EPOCH FROM (tmp_dt - dt))>5
                    then tmp_dt
                    else dt end dt2 from TMP
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(4条)

报告相同问题?

问题事件

  • 系统已结题 7月27日
  • 已采纳回答 7月19日
  • 修改了问题 7月16日
  • 修改了问题 7月16日
  • 展开全部

悬赏问题

  • ¥15 Attention is all you need 的代码运行
  • ¥15 一个服务器已经有一个系统了如果用usb再装一个系统,原来的系统会被覆盖掉吗
  • ¥15 使用esm_msa1_t12_100M_UR50S蛋白质语言模型进行零样本预测时,终端显示出了sequence handled的进度条,但是并不出结果就自动终止回到命令提示行了是怎么回事:
  • ¥15 前置放大电路与功率放大电路相连放大倍数出现问题
  • ¥30 关于<main>标签页面跳转的问题
  • ¥80 部署运行web自动化项目
  • ¥15 腾讯云如何建立同一个项目中物模型之间的联系
  • ¥30 VMware 云桌面水印如何添加
  • ¥15 用ns3仿真出5G核心网网元
  • ¥15 matlab答疑 关于海上风电的爬坡事件检测