所以我有一个包含许多日期时间字段的表,当我下载列表时,我必须将每个日期增加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天等等。
我一直在寻找,但无法弄清楚该怎么做。我不想使用光标,所以如果有人有任何建议,我将不胜感激。谢谢!
答案 0 :(得分: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)