如何选择零值的时间间隔

1 sql datetime join group-by intervals

我需要选择没有 (0) 数据的时间间隔。如何在 SQL 中做到这一点?

例子:

Time Data
10:00 0
10:15 0
10:30 1
10:45 0
11:00 12
11:15 0
11:30 0
11:45 0
12:00 7
Run Code Online (Sandbox Code Playgroud)

结果:

10:00 - 10:30
10:45 - 11:00
11:15 - 12:00
Run Code Online (Sandbox Code Playgroud)

Gor*_*off 5

您需要识别组,然后根据组进行聚合。

一种简单的方法是计算每个值上或之后的非零值的数量。这带来了结束时间:

select min(time), max(time)
from (select t.*,
             sum(case when data > 0 then 1 else 0 end) over (order by time desc) as grp
      from t
     ) t
group by grp
having min(data) = 0
order by min(time);
Run Code Online (Sandbox Code Playgroud)

是一个 SQL 小提琴。

注意:这使用了大多数数据库支持的标准 SQL 的窗口/分析函数。