2011-04-20 73 views
4

所以我有一个包含大量日期时间字段的表,并且当我下降列表时我必须将每个日期递增1天。因此,日期,因为他们存在将是:用更新语句增加日期时间字段

2011-04-19 
2011-04-19 
2011-04-19 
2011-04-19 

,我需要运行语句,使它们看起来像:

2011-04-19 
2011-04-20 
2011-04-21 
2011-04-22 

所以基本上,第一行保持不变,第二行得到一天添加,第三个获得2天添加,第四个获得3天添加等。

我一直在寻找,但不能完全弄清楚该怎么做。我不想使用游标,所以如果有人有任何建议,将不胜感激。谢谢!

回答

3

您可以使用会话变量:

SET @r := -1; 

UPDATE mytable 
SET  mydate = mydate + INTERVAL (@r := @r + 1) DAY; 

SQL Server 2005

WITH q AS 
     (
     SELECT *, 
       ROW_NUMBER() OVER (ORDER BY mydate) rn 
     FROM mytable 
     ) 
UPDATE q 
SET  mydate = DATEADD(d, rn - 1, mydate) 
+0

我想我应该澄清,我使用的SQL Server 2005。谢谢您的好意! – Scott 2011-04-20 15:16:41

+0

辉煌。谢谢!你的SQL-fu很强大。 – Scott 2011-04-20 15:23:46