-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathDate - Load Data.sql
229 lines (210 loc) · 13.2 KB
/
Date - Load Data.sql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
-- TRUNCATE TABLE Dimension.Date;
/**********************************************************************************************************************
** Description: Populate date dimension
** Runtime: 4.5 - 33 minutes (AMD Ryzen 7 3800x 8 cores /16 logical processors | 32 GB memory)
** Record Count: 3,652,058 records (479.102 MB uncompressed) for the date range of 0001-01-01 - 9999-12-30
** Compression: Page compression will result in a 237.883 MB size that will cause a slight CPU increase for queries
** ALTER TABLE Dimension.Date REBUILD PARTITION = ALL WITH (DATA_COMPRESSION = PAGE);
**********************************************************************************************************************/
DECLARE
@BeginDate datetime2(7) = '0001-01-01'
,@EndDate datetime2(7) = '9999-12-30' /* Need to exclude a day for the IsLastDayOfMonth check */
,@UseWorkDayOffTable bit = 0 /* Using the WorkDayOff table will override weekends being set as work days off */
,@SetSaturdayAsWorkDayOff bit = 1 /* 1 = All Saturdays will set Work Day to "No" */
,@SetSundayAsWorkDayOff bit = 1; /* 1 = All Sundays will set Work Day to "No" */
/*
** Number of months to add to the date to get the current Fiscal date.
** Set this to the number of months to add to the current date to get the beginning of the Fiscal year.
** For example, if the Fiscal year begins July 1, put a 6 there.
** Negative values are also allowed, thus if your 2019 Fiscal year begins in July of 2018, put a -6.
*/
DECLARE @FiscalYearMonthsOffset int = 0;
/* Holds a flag so we can determine if the date is the last day of month */
DECLARE @IsLastDayOfMonthFlag varchar(3);
/* Holds a flag so we can determine if the date is a work day */
DECLARE @IsWorkDayFlag varchar(3) = 'Yes';
/* These two counters are used in our loop. */
DECLARE @DateCounter datetime2(7); /* Current date in loop */
DECLARE @FiscalCounter datetime2(7); /* Fiscal Year Date in loop */
/* Create a temp table to store the Integration.WorkDayOff records */
IF OBJECT_ID('tempdb..#WorkDayOff') IS NOT NULL
BEGIN
DROP TABLE #WorkDayOff;
END;
CREATE TABLE #WorkDayOff (
DayOff date NOT NULL
,CONSTRAINT Temp_DayOff PRIMARY KEY CLUSTERED (DayOff ASC)
);
IF OBJECT_ID('Integration.WorkDayOff') IS NOT NULL
BEGIN
SET @UseWorkDayOffTable = 1;
INSERT INTO #WorkDayOff (DayOff) SELECT DayOff FROM Integration.WorkDayOff;
END;
SET NOCOUNT ON;
/* Start the counter at the begin date */
SET @DateCounter = @BeginDate;
INSERT INTO Dimension.Date (
[Date Key]
,[Full Date Time]
,[Date Name]
,[Date Name US]
,[Date Name EU]
,[Day Of Week]
,[Day Name Of Week]
,[Day Of Month]
,[Day Of Year]
,[Weekday Weekend]
,[Week Of Year]
,[Month Name]
,[Month Name Short]
,[Month Year]
,[Month Of Year]
,[Last Day Of Month]
,[Work Day]
,[Calendar Quarter]
,[Calendar Year]
,[Calendar Year Month]
,[Calendar Year Quarter]
,[Fiscal Month Of Year]
,[Fiscal Quarter]
,[Fiscal Quarter Name]
,[Fiscal Year]
,[Fiscal Year Name Short]
,[Fiscal Year Name Long]
,[Fiscal Year Month]
,[Fiscal Year Quarter]
)
VALUES
(-1
,N'0001-01-01T00:00:00'
,'UNKNOWN'
,'UNKNOWN'
,'UNKNOWN'
,2
,'UNKNOWN'
,1
,1
,'UNKNOWN'
,1
,'UNKNOWN'
,'UKN'
,'UNKNOWN'
,1
,'NA'
,'NA'
,1
,1
,'UNKNOWN'
,'UNKNWN'
,1
,1
,'UKN'
,1
,'UNKN'
,'UNKNWN'
,'UNKNWN'
,'UNKNWN');
WHILE @DateCounter <= @EndDate
BEGIN
/* Calculate the current Fiscal date as an offset of the current date in the loop*/
SET @FiscalCounter = DATEADD(MONTH, @FiscalYearMonthsOffset, @DateCounter);
/* Set value for IsLastDayOfMonthFlag */
IF MONTH(@DateCounter) = MONTH(DATEADD(DAY, 1, @DateCounter))
BEGIN
SET @IsLastDayOfMonthFlag = 'No';
END;
ELSE
BEGIN
SET @IsLastDayOfMonthFlag = 'Yes';
END;
/* Set value for IsWorkDayFlag */
SET @IsWorkDayFlag = 'Yes';
IF DATEPART(WEEKDAY, @DateCounter) = 7 /* Saturday */
AND @SetSaturdayAsWorkDayOff = 1
BEGIN
SET @IsWorkDayFlag = 'No';
END;
IF DATEPART(WEEKDAY, @DateCounter) = 1 /* Sunday */
AND @SetSundayAsWorkDayOff = 1
BEGIN
SET @IsWorkDayFlag = 'No';
END;
IF @UseWorkDayOffTable = 1
BEGIN
IF EXISTS (SELECT * FROM #WorkDayOff AS WDO WHERE WDO.DayOff = @DateCounter)
BEGIN
SET @IsWorkDayFlag = 'No';
END;
END;
/* Add a record into the date dimension table for this date */
INSERT INTO Dimension.Date (
[Date Key]
,[Full Date Time]
,[Date Name]
,[Date Name US]
,[Date Name EU]
,[Day Of Week]
,[Day Name Of Week]
,[Day Of Month]
,[Day Of Year]
,[Weekday Weekend]
,[Week Of Year]
,[Month Name]
,[Month Name Short]
,[Month Year]
,[Month Of Year]
,[Last Day Of Month]
,[Work Day]
,[Calendar Quarter]
,[Calendar Year]
,[Calendar Year Month]
,[Calendar Year Quarter]
,[Fiscal Month Of Year]
,[Fiscal Quarter]
,[Fiscal Quarter Name]
,[Fiscal Year]
,[Fiscal Year Name Short]
,[Fiscal Year Name Long]
,[Fiscal Year Month]
,[Fiscal Year Quarter]
)
VALUES
(CAST(CONVERT(char(8), @DateCounter, 112) AS int) /* Date Key */
,@DateCounter /* Full Date */
,RIGHT('000' + CAST(YEAR(@DateCounter) AS varchar(4)), 4) + '/' + RIGHT('00' + RTRIM(CAST(DATEPART(MONTH, @DateCounter) AS char(2))), 2) + '/' + RIGHT('00' + RTRIM(CAST(DATEPART(DAY, @DateCounter) AS char(2))), 2) /* Date Name */
,RIGHT('00' + RTRIM(CAST(DATEPART(MONTH, @DateCounter) AS char(2))), 2) + '/' + RIGHT('00' + RTRIM(CAST(DATEPART(DAY, @DateCounter) AS char(2))), 2) + '/' + RIGHT('000' + CAST(YEAR(@DateCounter) AS varchar(4)), 4) /* Date Name US */
,RIGHT('00' + RTRIM(CAST(DATEPART(DAY, @DateCounter) AS char(2))), 2) + '/' + RIGHT('00' + RTRIM(CAST(DATEPART(MONTH, @DateCounter) AS char(2))), 2) + '/' + RIGHT('000' + CAST(YEAR(@DateCounter) AS varchar(4)), 4) /* Date Name EU */
,DATEPART(WEEKDAY, @DateCounter) /* Day Of Week */
,DATENAME(WEEKDAY, @DateCounter) /* Day Name Of Week */
,DATENAME(DAY, @DateCounter) /* Day Of Month */
,DATENAME(DAYOFYEAR, @DateCounter) /* Day Of Year */
,CASE DATENAME(WEEKDAY, @DateCounter)
WHEN 'Saturday'
THEN 'Weekend'
WHEN 'Sunday'
THEN 'Weekend'
ELSE 'Weekday'
END /* Weekday Weekend */
,DATENAME(WEEK, @DateCounter) /* Week Of Year */
,DATENAME(MONTH, @DateCounter) /* Month Name */
,FORMAT(@DateCounter, 'MMM') /* Month Name Short */
,FORMAT(@DateCounter, 'MMM') + ' ' + RIGHT('000' + CAST(YEAR(@DateCounter) AS varchar(4)), 4) /* Month Year */
,MONTH(@DateCounter) /* Month Of Year */
,@IsLastDayOfMonthFlag /* Last Day Of Month */
,@IsWorkDayFlag /* Work Day */
,DATENAME(QUARTER, @DateCounter) /* Calendar Quarter */
,YEAR(@DateCounter) /* Calendar Year */
,RIGHT('000' + CAST(YEAR(@DateCounter) AS varchar(4)), 4) + '-' + RIGHT('00' + RTRIM(CAST(DATEPART(MONTH, @DateCounter) AS char(2))), 2) /* Calendar Year Month */
,RIGHT('000' + CAST(YEAR(@DateCounter) AS varchar(4)), 4) + 'Q' + DATENAME(QUARTER, @DateCounter) /* Calendar Year Quarter */
,MONTH(@FiscalCounter) /* Fiscal Month Of Year */
,DATENAME(QUARTER, @FiscalCounter) /* Fiscal Quarter */
,'FY' + CAST(DATENAME(QUARTER, @FiscalCounter) AS varchar(1)) /* Fiscal Quarter Name */
,YEAR(@FiscalCounter) /* Fiscal Year */
,'FY' + RIGHT('000' + CAST(YEAR(@DateCounter) AS varchar(4)), 2) /* Fiscal Year Name Short */
,'FY' + RIGHT('000' + CAST(YEAR(@DateCounter) AS varchar(4)), 4) /* Fiscal Year Name Long */
,RIGHT('000' + CAST(YEAR(@FiscalCounter) AS varchar(4)), 4) + '-' + RIGHT('00' + RTRIM(CAST(DATEPART(MONTH, @FiscalCounter) AS char(2))), 2) /* Fiscal Year Month */
,RIGHT('000' + CAST(YEAR(@FiscalCounter) AS varchar(4)), 4) + 'Q' + DATENAME(QUARTER, @FiscalCounter) /* Fiscal Year Quarter */
);
/* Increment the date counter for next pass thru the loop */
SET @DateCounter = DATEADD(DAY, 1, @DateCounter);
END;