sql >> Base de Datos >  >> RDS >> Sqlserver

Encuentre fechas consecutivas dentro de un lapso definido donde un Entrenador está disponible para programar

No estoy seguro de cómo funcionará esto con un conjunto de datos más grande, pero obtiene los resultados correctos para el conjunto de datos proporcionado. Se supone que los puntos de datos faltantes están disponibles.

declare @startDate datetime, @endDate datetime, @days int
select @startDate = '6/1/2013', @endDate='6/3/2013', @days=2

select trainer, min(date)
from
    (
    select  trainer,date,
            (select top 1 date
            from mySchedule sInner
            where sInner.date > sOuter.date
                    and sInner.trainer = sOuter.trainer
                    and sInner.Dirty = 1    
                    and sInner.date between @startDate and @endDate
            order by sInner.date) as nextDirtyDate
    from    mySchedule sOuter
    where sOuter.dirty=0
            and sOuter.date between @startDate and @endDate
    ) sub
group by trainer, nextDirtyDate
having dateDiff(d, min(date), isNull(nextDirtyDate,dateAdd(d,1,@endDate))) >= @days