[英]SQL Lead/Lag until a certain condition and update the previous/next rows with a value from the row that hits the condition
[英]SQL - check previous row until the requested value is found
我有一个如下数据集:
ID ReportingDate Status
123 05/05/2020 GREEN
123 12/05/2020 NONE
123 19/05/2020 NONE
123 26/05/2020 AMBER
123 02/06/2020 RED
123 09/06/2020 NONE
123 16/06/2020 GREEN
123 23/06/2020 NONE
123 30/06/2020 AMBER
我想忽略 NONE 状态并取之前的值,这可能是前一行,但有时是之前的 2 或 3 行。 基本上最后的 output 应该像“FINAL”列
ID ReportingDate Status FINAL
123 05/05/2020 GREEN GREEN
123 12/05/2020 NONE GREEN
123 19/05/2020 NONE GREEN
123 26/05/2020 AMBER AMBER
123 02/06/2020 RED RED
123 09/06/2020 NONE RED
123 16/06/2020 GREEN GREEN
123 23/06/2020 NONE GREEN
123 30/06/2020 AMBER AMBER
我尝试使用 LAG() 或 LEAD() 函数,但它不能按要求工作。
UPPER
(
CASE
WHEN psh.Status = 'NONE'
THEN LAG(psh.Status,1,psh.Status) OVER
(
PARTITION BY psh.ID
ORDER BY rp.ReportingDate
)
ELSE psh.Status
END
) AS OverallStatusHistory
你能告诉我,如果有办法如何实现它,好吗?
非常感谢!
您可以根据非'NONE'
值的计数来分配组。 然后传播价值:
select t.*,
max(nullif(status, 'NONE')) over (partition by id, grp) as imputed_status
from (select t.*,
sum(case when status = 'NONE' then 0 else 1 end) over (partition by id order by reportingdate) as grp
from t
) t;
这是一个 db<>fiddle。
SQL 标准实际上支持LAG()
上的IGNORE NULLS
选项(以及各种其他 window 函数)。 这样就可以在没有子查询的情况下解决这个问题。 不幸的是,SQL 服务器不(还???)支持该功能。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.