我需要将DateTime变量中的值转换为yyyy-mm-dd格式的varchar变量(没有时间部分)。

我怎么做呢?


当前回答

使用Microsoft SQL Server:

使用CONVERT语法:

CONVERT ( data_type [ ( length ) ] , expression [ , style ] )

例子:

SELECT CONVERT(varchar,d.dateValue,1-9)

对于样式,您可以在这里找到更多信息:MSDN - Cast和转换(Transact-SQL)。

其他回答

SQL Server 2012有一个新函数,FORMAT: http://msdn.microsoft.com/en-us/library/ee634924.aspx

并且您可以使用自定义日期时间格式字符串:http://msdn.microsoft.com/en-us/library/ee634398.aspx

这些页面暗示它也可以在SQL2008R2上使用,但是我没有一个方便的页面来测试这种情况。

示例用法(Australian datetime):

FORMAT(VALUE,'dd/MM/yyyy h:mm:ss tt')
CONVERT(VARCHAR, GETDATE(), 23)

试试下面的方法:

CONVERT(VARCHAR(10),GetDate(),102)

然后需要将“。”替换为“-”。

这里有一个网站可以提供帮助 http://www.mssqltips.com/tip.asp?tip=1145

你可以转换你的日期在许多格式,语法很简单使用:

CONVERT('TheTypeYouWant', 'TheDateToConvert', 'TheCodeForFormating' * )
CONVERT(NVARCHAR(10), DATE_OF_DAY, 103) => 15/09/2016

代码是一个整数,这里3是第三个没有世纪的格式,如果你想要世纪,只需将代码更改为103。

在你的情况下,我只是转换和限制大小的nvarchar(10)像这样:

CONVERT(NVARCHAR(10), MY_DATE_TIME, 120) => 2016-09-15

详见:http://www.w3schools.com/sql/func_convert.asp

另一个解决方案(如果你的日期是一个Datetime)是一个简单的CAST:

CAST(MY_DATE_TIME as DATE) => 2016-09-15

你没有说什么语言,但我假设是c# /。NET,因为它具有原生DateTime数据类型。在这种情况下,只需使用ToString方法进行转换,并使用如下格式说明符:

DateTime d = DateTime.Today;
string result = d.ToString("yyyy-MM-dd");

但是,我要警告不要在数据库查询中使用它或连接到SQL语句中。数据库需要使用特定的格式化字符串。如果您想要完成这个任务,最好将时间部分归零,并使用DateTime作为SQL参数。