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


当前回答

在转换为日期后将其转换回datetime,以便在需要时保持相同的datatime

select Convert(datetime, Convert(date, getdate())  )

其他回答

个人最喜欢的:

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

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

2008年旧版本:

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

CAST(
        FLOOR( 
             CAST( GETDATE() AS FLOAT ) 
        )

AS DATETIME
)

http://www.bennadel.com/blog/122-Getting-Only-the-Date-Part-of-a-Date-Time-Stamp-in-SQL-Server.htm

有点晚了,但是可以使用ODBC的“curdate”函数(尖括号中的“fn”是ODBC函数转义序列)。

SELECT {fn curdate()} 

输出:2013-02-01