首页 > 解决方案 > 使用滞后根据当前行值选择上一行

问题描述

我有一个如下所示的表格

person_id  source_system   r_diff
  1              A          NULL
  1              B           0
  1              B           9
  1              A           15
  1              A           574
  1              B           0
  1              A           63
  1              A           136
  1              B           0

我想根据Or operation2 条规则选择数据

a) 选择所有记录source_system = B

b) 选择 r_diff = 0 的 n 和 n-1 行。

例如,在上面的数据中,您可以找到r_diff = 0行号2,6,9。所以,我想选择第 1,2 和 5,6 和 8,9 行。你可以看到我是如何选择 n 和 n-1 行的

我尝试了以下

select *, lag(*) from table A
where (r_diff is NULL or r_diff = 0) or source_system in ('B')

我希望我的输出如下所示

person_id  source_system   r_diff
  1              A          NULL
  1              B           0
  1              B           9
  1              A           574
  1              B           0
  1              A           136
  1              B           0

标签: sqlpostgresqlgroup-bywindow-functions

解决方案


SQL 表表示无序集。您的问题假定表中的排序。. . 所以我必须假设有一列指定排序。

您可以使用lead()子查询来处理此问题:

select t.*
from (select t.*,
             lead(r_dif) over (partition by person_id order by <ordering column<>) as next_r_dif
      from t
     ) t
where 0 in (next_r_dif, r_dif)

推荐阅读