繁体   English   中英

在SQL中对连续的时间间隔进行分组

[英]Grouping consecutive time intervals in SQL

我有类似的东西

+------+-----+-----------+---------+
| Room | Day | StartTime | EndTime |
+------+-----+-----------+---------+
| 1    | 1   | 08:00     | 09:00   |
+------+-----+-----------+---------+
| 1    | 1   | 09:00     | 10:00   |
+------+-----+-----------+---------+
| 1    | 1   | 13:00     | 14:00   |
+------+-----+-----------+---------+
| 2    | 2   | 07:00     | 08:00   |
+------+-----+-----------+---------+

我想按房间,日期和时间间隔进行分组,但只有连续的时间间隔,例如:

+------+-----+-----------+---------+
| Room | Day | StartTime | EndTime |
+------+-----+-----------+---------+
| 1    | 1   | 08:00     | 10:00   |
+------+-----+-----------+---------+
| 1    | 1   | 13:00     | 14:00   |
+------+-----+-----------+---------+
| 2    | 2   | 07:00     | 08:00   |
+------+-----+-----------+---------+

我有这个代码,但我不满意,因为也是分组差距,并抛出以下结果:

SELECT
sd.Cod_Room,
sd.Cod_Day,
MIN(bd.StartTime) as StartTime,
MAX(bd.EndTime) as EndTime
FROM
Schedule.ScheduleDetail AS sd
INNER JOIN Schedule.BlockDetail AS bd ON sd.Cod_BlockDetail = bd.Cod_BlockDetail
GROUP BY
sd.Room, sd.Day

+------+-----+-----------+---------+
| Room | Day | StartTime | EndTime |
+------+-----+-----------+---------+
| 1    | 1   | 08:00     | 14:00   |
+------+-----+-----------+---------+
| 2    | 2   | 07:00     | 08:00   |
+------+-----+-----------+---------+

我正在阅读关于lead()和lag()的内容,但这比我想象的要花费更多时间。 我感谢您的帮助

您可以通过识别重叠的组然后累积此值来定义组来完成此操作。 以下假设SQL Server 2012+:

with t as (
      select sd.Cod_Room, sd.Cod_Day, bd.StartTime, bd.EndTime
      from Schedule.ScheduleDetail sd INNER JOIN
           Schedule.BlockDetail bd
           ON sd.Cod_BlockDetail = bd.Cod_BlockDetail
     )
select cod_room, cod_day,
       min(startTime) as startTime, max(endTime) as endTime
from (select t.*,
             sum(IsStart) over (partition by cod_room, cod_day order by StartTime) as grp
      from (select t.*, 
                   (case when StartTime = lag(EndTime) over (partition by cod_room, cod_day order by StartTime)
                         then 0 else 1
                    end) as IsStart
            from t
           ) t
     ) t
group by cod_room, cod_day, grp;

暂无
暂无

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

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