当我选择日期在SQL返回为2011-02-25 21:17:33.933。但我只需要日期部分,即2011-02-25。我该怎么做呢?


当前回答

个人最喜欢的:

select convert(datetime, convert(int, getdate()))

其他回答

使用CAST(GETDATE()作为日期)为我工作

我猜他想要根绳子。

select convert(varchar(10), '2011-02-25 21:17:33.933', 120)

这里的120告诉转换函数,我们以以下格式传递输入日期:yyyy-mm-dd hh:mi:ss。

2008年旧版本:

Select dateadd (day, datediff (day, 0, getdate ()), 0)

如果你想返回一个日期类型只是一个日期使用

CONVERT(date, SYSDATETIME())

or

SELECT CONVERT(date,SYSDATETIME()) 

or

DECLARE @DateOnly Datetime
SET @DateOnly=CONVERT(date,SYSDATETIME())

最快的是date ediff。

select dateadd(d, datediff(d,0, [datecolumn]), 0), other..
from tbl

但是如果你只需要使用这个值,那么你可以跳过dateadd,例如。

select ...
WHERE somedate <= datediff(d, 0, getdate())

表达式datediff(d, 0, getdate())足以返回今天的日期而不包含时间部分。