I am going to pick up speed with my series of short articles or tidbits on Transaction SQL date/time functions.
Most, if not all, modern day computer systems collect data which contains dates and times.
Not only is it important to know when a sales order came in, but we should fulfill the request using some type of queue (LIFO). If if was a stack (FIFO) implementation, the first person may never get his order!
Today, I will be exploring the DATEPART() function. This function has 15 different input parameters that can be passed to change the resulting output.
In short, the function takes a date part and date time variables as input returns the part that you want as an integer. I will be concentrating on how to extract the month (MM, M) in this article.
The examples below are sample calls to the function. The inputs puts are valid date, null value and a empty string.
1 2 3 4 5 6 7 8 9 10 11 |
-- -- Functions to get date and time parts as INT -- -- Month SELECT DATEPART(MM, SYSDATETIME()) AS MONTH_A_INT, DATEPART(M, SYSDATETIME()) AS MONTH_B_INT, DATEPART(MM, NULL) AS MONTH_C_INT, DATEPART(M, '') AS MONTH_D_INT GO |
The output from the test is listed below. It is surprising that an empty string returns a value of 1.
1 2 3 4 5 |
output: MONTH_A_INT MONTH_B_INT MONTH_C_INT MONTH_D_INT ----------- ----------- ----------- ----------- 11 11 NULL 1 |
In as nutshell, pass one of the two date part parameters to extract the month as an integer from the date time variable.