利用master..spt_values来生成连续日期

  1. declare @date datetime  
  2. set @date='2009-02-05'  
  3. select [day]=convert(varchar,DATEADD(mm,DATEDIFF(mm,0,@date),0)+number,121)  
  4. from master..spt_values  
  5. where type='p'  
  6. and number< datediff(dd,@date,dateadd(mm,1,@date))<pre name="code" class="sql">--输出2008年至今以来的月份列表:  
  7. create table Mon  
  8. (  
  9. ID int identity(1,1),  
  10. Mon varchar(6)  
  11. )  
  12. GO  
  13. DECLARE  
  14. @BeginMonth varchar(6),  
  15. @EndMonth varchar(6)  
  16. SELECT  
  17. @BeginMonth='200801',  
  18. @EndMonth='200906'  
  19. INSERT Mon(Mon)  
  20. SELECT  
  21. CONVERT(VARCHAR(6),DATEADD(month,number,@BeginMonth+'01'),112)  
  22. FROM  
  23. master..spt_values  
  24. WHERE  
  25. type='P'  
  26. and  
  27. DATEADD(month,number,@BeginMonth+'01')<=@EndMonth+'01'  
  28. SELECT * FROM Mon  
  29. DROP TABLE Mon  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值