एक विधि पुनरावर्ती CTE है:
with cte as (
select dateadd(day, 1 - day(@startdate), @startdate) as som,
eomonth(@startdate) as eom
union all
select dateadd(month, 1, som), eomonth(dateadd(month, 1, som))
from cte
where dateadd(month, 1, som) < @enddate
)
select *
from cte;
यदि आप महीने का नाम चाहते हैं, तो आप datename(month, som)
. का उपयोग कर सकते हैं ।