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)
您需要识别组,然后根据组进行聚合。
一种简单的方法是计算每个值上或之后的非零值的数量。这带来了结束时间:
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 的窗口/分析函数。