SELECT GETDATE()

返回时间:2008-09-22 15:24:13.790

我想要没有时间部分的日期部分:2008-09-22 00:00:00.000

我怎么能得到那个?


当前回答

我的风格

      select Convert(smalldatetime,Convert(int,Convert(float,getdate())))

其他回答

从SQL SERVER 2012开始,您可以执行以下操作:

选择格式(GETDATE(),'yyyy-MM-dd 00:00:00.000')

为什么不使用DATE_FORMAT(your_datetiem_column,'%d-%m-%Y')?

示例:从table_name中选择DATE_FORMAT(some_datetime_column,“%d-%m-%Y”)

您可以通过重新排列“%d-%m-%Y”部分来更改m、d和year的顺序

以日期格式返回

CAST(订单日期AS日期)

以上代码将在sqlserver2010中运行

它将于2013年12月12日回归

对于SQL Server 2012,请使用以下代码

CONVERT(VARCHAR(10), OrderDate , 111)
select cast(createddate as date) as derivedate from table 

createdate是您的datetime列,这适用于sqlserver

如果要将结果分配给列或变量,请为其指定DATE类型,并且转换是隐式的。

DECLARE @Date DATE = GETDATE()   

SELECT @Date   --> 2017-05-03