Суммируйте дни в месяце на основе диапазонов дат - PullRequest
5 голосов
/ 06 марта 2011

Будучи в первую очередь разработчиком на C #, я стараюсь изо всех сил пытаться создать решение на основе чистого T-SQL для решения проблемы суммирования дней / месяцев с учетом набора диапазонов дат.

набор данных выглядит примерно так:

UserID  Department  StartDate   EndDate
======  ==========  ==========  ==========
1       A           2011-01-02  2011-01-05
1       A           2011-01-20  2011-01-25
1       A           2011-02-25  2011-03-05
1       B           2011-01-21  2011-01-22
2       A           2011-01-01  2011-01-20
3       C           2011-01-01  2011-02-03

Диапазоны дат не перекрываются, могут охватывать несколько месяцев, может существовать несколько диапазонов для конкретного пользователя и отдела в течение одного месяца.То, что я хотел бы сделать, это суммировать количество дней (включительно) на пользователя, отдел, год и месяц, как это (с оговорками для любых математических ошибок в моем примере ...):

UserID  Department  Year  Month  Days
======  ==========  ====  =====  ====
1       A           2011  01     10
1       A           2011  02     4
1       A           2011  03     5
1       B           2011  01     2
2       A           2011  01     20
3       C           2011  01     31
3       C           2011  02     3

Эти данные заносятся в новую таблицу, используемую инструментами отчетности.Я надеюсь, что описание проблемы достаточно ясное, это моя первая публикация здесь, будьте осторожны: -)

Заранее спасибо!

1 Ответ

8 голосов
/ 06 марта 2011

Рабочий образец

-- sample data in a temp table
declare @t table (UserID int, Department char(1), StartDate datetime, EndDate datetime)
insert @t select
1 ,'A', '2011-01-02','2011-01-05'union all select
1 ,'A', '2011-01-20','2011-01-25'union all select
1 ,'A', '2011-02-25','2011-03-05'union all select
1 ,'B', '2011-01-21','2011-01-22'union all select
2 ,'A', '2011-01-01','2011-01-20'union all select
3 ,'C', '2011-01-01','2011-02-03'

-- the query you need is below this line    

select UserID, Department,
    YEAR(StartDate+v.number) Year,
    MONTH(StartDate+v.number) Month, COUNT(*) Days
from @t t
inner join master..spt_values v
  on v.type='P' and v.number <= DATEDIFF(d, startdate, enddate)
group by UserID, Department, YEAR(StartDate+v.number), MONTH(StartDate+v.number)
order by UserID, Department, Year, Month
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...