Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/sql-server-2005/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Sql 使用update语句递增datetime字段_Sql_Sql Server 2005 - Fatal编程技术网

Sql 使用update语句递增datetime字段

Sql 使用update语句递增datetime字段,sql,sql-server-2005,Sql,Sql Server 2005,因此,我有一个表,其中包含许多datetime字段,当我下降列表时,我必须将每个日期增加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天,以此类推 我一直在找,但不知道该怎么办。我不想使用光标,所以如果有人有任何建议,我将不胜感激

因此,我有一个表,其中包含许多datetime字段,当我下降列表时,我必须将每个日期增加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天,以此类推


我一直在找,但不知道该怎么办。我不想使用光标,所以如果有人有任何建议,我将不胜感激。谢谢

您可以使用会话变量:

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)

我想我应该澄清一下,我使用的是SQLServer2005。谢谢你!明亮的非常感谢。你的意志力很强。