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


当前回答

在PLSQL中可以使用

to_char(SYSDATE,'dd/mm/yyyy')

其他回答

你可以这样用

SELECT Convert(varchar(10), GETDATE(),120) 

你也可以试试这个。

SELECT CONVERT(DATE, GETDATE(), 120)

我将创建一个标量函数,并使用format()设置希望看到的数据类型。它必须便于以后的维护。

最快的是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())足以返回今天的日期而不包含时间部分。

如果你需要时间为0,比如2018-01-17 00:00:00.000:

Select convert (datetime, convert (date, getdate ()), 121)