Try this query:
;WITH DateTable AS
(
SELECT DATEADD(month, DATEDIFF(month, 0, GETDATE()), 0) AS [date]
UNION ALL
SELECT DATEADD(DAY, 1, [date])
FROM DateTable
WHERE DATEADD(DAY, 1, [date]) <= EOMONTH(GETDATE())
)
SELECT CAST([date] AS date) DaysOfMonth
FROM DateTable
Best regards,
Cosmog Hong
If the answer is the right solution, please click "Accept Answer" and kindly upvote it. If you have extra questions about this answer, please click "Comment".
Note: Please follow the steps in our Documentation to enable e-mail notifications if you want to receive the related email notification for this thread.