Мне нужно преобразовать строки в столбцы на все недели для данного подтверждения, но в моем запросе оно выполняется только в течение одной недели, но существует несколько недель при одном ID. `преобразование поворота в течение нескольких недель
ConfirmationId TimeSheetDate DayName WorkingHours
-------------------- ----------------------- ------------------------------ ----------------------
1 2006-07-18 00:00:00.000 Tuesday 8
1 2006-07-19 00:00:00.000 Wednesday 8
1 2006-07-20 00:00:00.000 Thursday 8
1 2006-07-21 00:00:00.000 Friday 8
1 2006-07-24 00:00:00.000 Monday 8
1 2006-07-25 00:00:00.000 Tuesday 8
1 2006-07-26 00:00:00.000 Wednesday 8
1 2006-07-27 00:00:00.000 Thursday 8
1 2006-07-28 00:00:00.000 Friday 8
1 2006-08-07 00:00:00.000 Monday 8
1 2006-08-08 00:00:00.000 Tuesday 8
1 2006-08-09 00:00:00.000 Wednesday 8
1 2006-08-10 00:00:00.000 Thursday 8
1 2006-08-11 00:00:00.000 Friday 8
1 2006-08-29 00:00:00.000 Tuesday 8
1 2006-08-30 00:00:00.000 Wednesday 8
1 2006-08-31 00:00:00.000 Thursday 8
1 2006-09-01 00:00:00.000 Friday 8
1 2006-10-09 00:00:00.000 Monday 8
1 2006-10-10 00:00:00.000 Tuesday 8
1 2006-10-11 00:00:00.000 Wednesday 8
1 2006-10-12 00:00:00.000 Thursday 8
1 2006-10-13 00:00:00.000 Friday 8
1 2006-10-23 00:00:00.000 Monday 8
1 2006-10-24 00:00:00.000 Tuesday 8
2 2007-06-22 00:00:00.000 Friday 8
2 2007-06-25 00:00:00.000 Monday 8
2 2007-06-26 00:00:00.000 Tuesday 8
2 2007-06-27 00:00:00.000 Wednesday 8
2 2007-07-02 00:00:00.000 Monday 8
2 2007-07-03 00:00:00.000 Tuesday 8
2 2007-07-05 00:00:00.000 Thursday 8
2 2007-07-06 00:00:00.000 Friday 8
2 2007-07-09 00:00:00.000 Monday 8
2 2007-07-10 00:00:00.000 Tuesday 8
2 2007-07-11 00:00:00.000 Wednesday 8
2 2007-07-12 00:00:00.000 Thursday 8
2 2007-07-13 00:00:00.000 Friday 8
2 2007-07-16 00:00:00.000 Monday 8
2 2007-07-17 00:00:00.000 Tuesday 8
2 2007-07-18 00:00:00.000 Wednesday 8
2 2007-07-19 00:00:00.000 Thursday 8
2 2007-07-20 00:00:00.000 Friday 8
2 2007-07-23 00:00:00.000 Monday 8
2 2007-07-24 00:00:00.000 Tuesday 8
2 2007-07-25 00:00:00.000 Wednesday 8
2 2007-07-26 00:00:00.000 Thursday 8
2 2007-07-27 00:00:00.000 Friday 8
2 2007-07-30 00:00:00.000 Monday 8
2 2007-07-31 00:00:00.000 Tuesday 8
2 2007-08-01 00:00:00.000 Wednesday 8
2 2007-08-02 00:00:00.000 Thursday 8
2 2007-08-03 00:00:00.000 Friday 8
2 2007-08-06 00:00:00.000 Monday 8
2 2007-08-07 00:00:00.000 Tuesday 8
2 2007-08-08 00:00:00.000 Wednesday 8
2 2007-08-09 00:00:00.000 Thursday 8
2 2007-08-10 00:00:00.000 Friday 8
2 2007-08-13 00:00:00.000 Monday 8
2 2007-08-14 00:00:00.000 Tuesday 8
2 2007-08-15 00:00:00.000 Wednesday 8
2 2007-08-16 00:00:00.000 Thursday 8
2 2007-08-17 00:00:00.000 Friday 8
2 2007-08-20 00:00:00.000 Monday 8
2 2007-08-21 00:00:00.000 Tuesday 8
2 2007-08-22 00:00:00.000 Wednesday 8
мне нужно привести в такой форме:
ConfirmationId weekstartdate weekenddate Monday Tuesday Wednesday Thursday Friday Saturday Sunday
1 16/07/2007 23/07/2007 NULL NULL 8 8 8 NULL NULL
1 24/07/2007 30/07/2007 8 8 8 8 8 NULL NULL
2 18/06/2007 24/06/2007 NULL NULL NULL NULL 8 NULL NULL
2 25/06/2007 1/07/2007 8 8 8 NULL NULL NULL NULL
2 2/07/2007 8/07/2007 8 8 NULL 8 8 NULL NULL
Что я пытался до сих пор:
select Confirmationid,[Monday],[Tuesday],[Wednesday],[Thursday],[Friday],[Saturday],[Sunday]
from
(
Select confirmationid,WorkingHours,TimeSheetDate,[DayName] from #temp1
) d
pivot(
min(WorkingHours) for
[DayName] in ([Monday],[Tuesday],[Wednesday],[Thursday],[Friday],[Saturday],[Sunday])
)piv order by ConfirmationId
это дает мне результат: что совершенно неправильно.
У меня нет этой таблицы tlkp_Calender, я считаю, что вы создали эту таблицу. – dawncode
Да, вам нужно создать таблицу календаря, для ее создания имеется множество сценариев, и они являются неоценимыми инструментами. –