Sql Server 生成连续日期的方法总结

第一种,利用master..spt_values来生成连续日期
[sql]  view plain  copy
 print ?
  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))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  
 这是利用表master..sp_values查询连续数字的,但是范围要在2048以内,不包括2048 
  
[sql]  view plain  copy
 print ?
  1. select number from  
  2. master..spt_values  
  3. where type='P' and number between 1 and 1000  

第二种,直接生成连续日期,表temptab(date) 只是临时表
[sql]  view plain  copy
 print ?
  1. Declare @mindate datetime  
  2. Declare @maxdate datetime  
  3. set @mindate  = '2010-01-01'  
  4. set @maxdate  = '2010-02-01'  
  5. ;with temptab(dateas  
  6. select @mindate  
  7. union all  
  8. select dateadd(d,1,temptab.dateas date  
  9. from temptab  
  10. where dateadd(d,1,temptab.date)<=@maxdate  
  11. )  
  12. select * from temptab  
出处 http://www.cnblogs.com/envelope/archive/2010/04/27/1721786.html

你可能感兴趣的:(SQL)