, , , .
, , .
, , .
select
t1.id,
t1.start_time,
t1.end_time,
t1.end_time - t1.start_time as duration,
sum(
if(t2.start_time < t1.start_time and t2.end_time > t1.end_time , t1.end_time - t1.start_time, 0)
+ if(t2.start_time >= t1.start_time and t2.end_time <= t1.end_time , t2.end_time - t2.start_time, 0)
+ if(t2.start_time < t1.start_time and t2.end_time > t1.start_time and t2.end_time < t1.end_time , t2.end_time - t1.start_time, 0)
+ if(t2.start_time < t1.end_time and t2.end_time > t1.end_time and t2.start_time > t1.start_time, t1.end_time - t2.start_time, 0)
) as overlap
from
times t1
left join times t2 on
t2.id > t1.id
and (
(t2.start_time < t1.start_time and t2.end_time > t1.end_time )
or (t2.start_time >= t1.start_time and t2.end_time <= t1.end_time )
or (t2.start_time < t1.start_time and t2.end_time > t1.start_time)
or (t2.start_time < t1.end_time and t2.end_time > t1.end_time )
)
group by
t1.id
, , :
select
sum(t.duration) - sum(t.overlap) as filtered_duration
from
(
OTHER QUERY HERE
) as t
, :
select
sum(t.duration) - sum(t.overlap) as filtered_duration
from
(
select
t1.id,
t1.start_time,
t1.end_time,
t1.end_time - t1.start_time as duration,
sum(
if(t2.start_time < t1.start_time and t2.end_time > t1.end_time , t1.end_time - t1.start_time, 0)
+ if(t2.start_time >= t1.start_time and t2.end_time <= t1.end_time , t2.end_time - t2.start_time, 0)
+ if(t2.start_time < t1.start_time and t2.end_time > t1.start_time and t2.end_time < t1.end_time , t2.end_time - t1.start_time, 0)
+ if(t2.start_time < t1.end_time and t2.end_time > t1.end_time and t2.start_time > t1.start_time, t1.end_time - t2.start_time, 0)
) as overlap
from
times t1
left join times t2 on
t2.id > t1.id
and (
(t2.start_time < t1.start_time and t2.end_time > t1.end_time )
or (t2.start_time >= t1.start_time and t2.end_time <= t1.end_time )
or (t2.start_time < t1.start_time and t2.end_time > t1.start_time)
or (t2.start_time < t1.end_time and t2.end_time > t1.end_time )
)
group by
t1.id
) as t