Могу ли я рассчитать совокупную продолжительность для нескольких строк с одной строкой в ​​день? - PullRequest
0 голосов
/ 28 февраля 2020

Я создаю отчет об отсутствии персонала. Данные об отсутствии хранятся в базе данных как одна строка в день (столбцы: EmployeeId, Дата отсутствия, Длительность). Поэтому, если я не работаю со вторника 11 февраля 2020 года по пятницу 21 февраля 2020 года включительно, в таблице будет 9 строк:

11 февраля 2020 года - 1 день

12 февраля 2020 года - 1 день

13 февраля 2020 года - 1 день

14 февраля 2020 года - 1 день

17 февраля 2020 года - 1 день

18 февраля 2020 года - 1 день

19 февраля 2020 г. - 1 день

20 февраля 2020 г. - 1 день

21 февраля 2020 г. - 1 день

(см. Скриншот ниже)

6 February 2020 - 1 day

HR хотел бы видеть одну запись в отчете за непрерывный период отсутствия:

enter image description here

Мой вопрос - без использования курсора, как я могу вычислить значение в SQL (еще сложнее, потому что я должен сделать это с помощью Linq до SQL, но я мог бы поменяться местами это для хранимой процедуры. Обратите внимание, что критерий для смежных данных - смежные рабочие дни, исключая выходные и праздничные дни. Я надеюсь, что Я ясно ... извинения, если нет.

1 Ответ

0 голосов
/ 28 февраля 2020

Это форма пробелов и островков. В этом случае используйте lag(), чтобы увидеть, перекрываются ли два отпуска, а затем накопительную сумму:

select employee, min(absent_from), max(absent_to)
from (select t.*,
             sum(case when prev_absent_to = dateadd(day, -1, absent_from) then 0 else 1
                 end) over (partition by employee order by absent_to) as grp
      from (select t.*,
                   lag(absent_to) over (partition by employee order by absent_from) as prev_absent_to
            from t
           ) t
     ) t
group by employee, grp;

Если вам нужно работать с выходными и праздничными днями, тогда вам нужен календарь.

...