如何在SQL Server中动态更改日期
我的过程输出如下如何在SQL Server中动态更改日期,sql,sql-server,Sql,Sql Server,我的过程输出如下 Jan 1 1900 10:30PM Jan 1 1900 10:45PM Jan 1 1900 11:00PM Jan 1 1900 11:30PM Jan 1 1900 11:45PM Jan 2 1900 12:00AM Jan 2 1900 12:15AM Jan 2 1900 12:30AM Jan 2 1900 12:45AM Jan 2 1900 1:00AM 我想在12:00AM之后添加当前日期和时间以及更改日期 像这样: Friday,
Jan 1 1900 10:30PM
Jan 1 1900 10:45PM
Jan 1 1900 11:00PM
Jan 1 1900 11:30PM
Jan 1 1900 11:45PM
Jan 2 1900 12:00AM
Jan 2 1900 12:15AM
Jan 2 1900 12:30AM
Jan 2 1900 12:45AM
Jan 2 1900 1:00AM
我想在12:00AM之后添加当前日期和时间以及更改日期
像这样:
Friday,MAY,18 10:30PM
Friday,MAY,18 10:45PM
Friday,MAY,18 11:00PM
Friday,MAY,18 11:30PM
Friday,MAY,18 11:45PM
Friday,MAY,19 12:00AM
Friday,MAY,19 12:15AM
Friday,MAY,19 12:30AM
Friday,MAY,19 12:45AM
Friday,MAY,19 1:00AM
怎么做
提前谢谢我想你需要这个
DECLARE @tt TABLE (Sday VARCHAR(50))
INSERT INTO @tt VALUES('Jan 1 1900 10:30PM'),('Jan 1 1900 10:45PM'),('Jan 1 1900 11:00PM'),('Jan 1 1900 11:30PM'),('Jan 1 1900 11:45PM'),('Jan 2 1900 12:00AM'),('Jan 2 1900 12:15AM'),('Jan 2 1900 12:30AM'),('Jan 2 1900 12:45AM'),('Jan 2 1900 1:00AM')
SELECT Sday,DATEADD(DAY,(DATEDIFF(DAY,'1900-01-01',GETDATE())),Sday) AS resultAsDatetime,
CONVERT(VARCHAR(50),DATEADD(DAY,(DATEDIFF(DAY,'1900-01-01',GETDATE())),Sday),109) AS result
FROM @tt
又回来了
Jan 1 1900 10:30PM 2012-05-18 22:30:00.000 May 18 2012 10:30:00:000PM
Jan 1 1900 10:45PM 2012-05-18 22:45:00.000 May 18 2012 10:45:00:000PM
Jan 1 1900 11:00PM 2012-05-18 23:00:00.000 May 18 2012 11:00:00:000PM
Jan 1 1900 11:30PM 2012-05-18 23:30:00.000 May 18 2012 11:30:00:000PM
Jan 1 1900 11:45PM 2012-05-18 23:45:00.000 May 18 2012 11:45:00:000PM
Jan 2 1900 12:00AM 2012-05-19 00:00:00.000 May 19 2012 12:00:00:000AM
Jan 2 1900 12:15AM 2012-05-19 00:15:00.000 May 19 2012 12:15:00:000AM
Jan 2 1900 12:30AM 2012-05-19 00:30:00.000 May 19 2012 12:30:00:000AM
Jan 2 1900 12:45AM 2012-05-19 00:45:00.000 May 19 2012 12:45:00:000AM
Jan 2 1900 1:00AM 2012-05-19 01:00:00.000 May 19 2012 1:00:00:000AM
显然,您可以选择正确的格式将DATETIME转换为CONVERT函数中记录的VARCHAR,但我认为这不需要帮助。
希望这有帮助。来自SQL Server 2008:
select YourTimeCol+cast(getdate() as date)
from YourTable
select YourTimeCol+dateadd(day, datediff(day, 0, getdate()), 0)
from YourTable
SQL Server 2008之前版本:
select YourTimeCol+cast(getdate() as date)
from YourTable
select YourTimeCol+dateadd(day, datediff(day, 0, getdate()), 0)
from YourTable
谢谢为我工作的“埃多”。。。再次感谢你。这里的另一个步骤是如何仅选择大于服务器时间(currunt time)的值。我们可以在插入@tt时执行此操作吗。。(请用甲酸盐)你是说这个吗<代码>选择Sday、DATEADD(DAY、(DATEDIFF(DAY,'1900-01-01',GETDATE())、Sday)作为结果DateTime、CONVERT(VARCHAR(50)、DATEADD(DAY、(DATEDIFF(DAY,'1900-01-01',GETDATE())、Sday)、109)作为@tt的结果,其中DATEADD(DAY,(DATEDIFF(DAY,'1900-01-01',GETDATE())、GETDATE())>GETDATE()