SQL生成日期列

--生成一个日期范围,如2014.01、2014.02...
--@type 自增部分类型 y,m,d,w
--@@startDate 开始日期
--@@endDate   结束日期
create function CreateDateRange(@type char(1),@startDate date,@endDate date)
returns @DateValueRange table(datevalue date)
as
begin

declare @tempDate date=@startDate

while @tempDate<@endDate
begin
 select @tempDate= case @type when  'y' then dateadd(yy, 1, @tempDate) when  'm' then dateadd(mm, 1, @tempDate) when 'd' then dateadd(dd, 1, @tempDate) when  'w' then dateadd(ww, 1, @tempDate)end 
 insert into @DateValueRange(datevalue)select @tempDate
end 
 return  
      
end
go
select * from CreateDateRange('d',GETDATE(),GETDATE()+10)

 

posted @ 2019-04-11 23:22  唧唧复唧唧木兰当户织  阅读(2109)  评论(0编辑  收藏  举报