繁体   English   中英

SQL:检查n个连续记录是否大于某个值

[英]SQL: Check if n consecutive records are greater than some value

我有一个包含数字的表。 我必须找出是否存在连续n个大于某个阈值m的情况。 例如

id      delta         
---------------
1        10  
4        15 
11       22 
23       23  
46       21
57       9

所以在这里,如果我想知道是否有3个连续记录的值大于20,那么我应该得到True。 当我检查4个连续记录时为False。 那可能吗? 这是在Apache Spark SQL上。 谢谢。

您可以使用lag来做到这一点:

select t.*
from (select t.*,
             lag(val, 1) over (order by id) as val_1,
             lag(val, 2) over (order by id) as val_2
      from t
     ) t
where val > 20 and val_1 > 20 and val_2 > 20;

这将返回第一行,它是每个三人行的一部分。 如果您只想对/错:

select (case when count(*) > 0 then 'true' else 'false' end)
from (select t.*,
             lag(val, 1) over (order by id) as val_1,
             lag(val, 2) over (order by id) as val_2
      from t
     ) t
where val > 20 and val_1 > 20 and val_2 > 20;

编辑:

我错过了不要超过3的部分。因此,您可以增强这一点:

select (case when count(*) > 0 then 'true' else 'false' end)
from (select t.*,
             lag(val, 1) over (order by id) as val_1,
             lag(val, 2) over (order by id) as val_2,
             lag(val, 3) over (order by id) as val_3,
             lead(val, 1) over (order by id) as val_next_1
      from t
     ) t
where (val_3 <= 20 or val_3 is null) and
      (val_2 > 20 and val_1 > 20 and val > 20) and
      (val_next_1 <= 20 or val_next_1 is null);

这有点棘手,因为值可以在行的开头或结尾。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM