我需要将DateTime变量中的值转换为yyyy-mm-dd格式的varchar变量(没有时间部分)。
我怎么做呢?
我需要将DateTime变量中的值转换为yyyy-mm-dd格式的varchar变量(没有时间部分)。
我怎么做呢?
当前回答
这就是我怎么做的:CONVERT(NVARCHAR(10), DATE1, 103))
其他回答
试试下面的方法:
CONVERT(varchar(10), [MyDateTimecolumn], 20)
对于一个完整的约会时间,而不仅仅是约会,请:
CONVERT(varchar(23), [MyDateTimecolumn], 121)
查看本页转换样式:
http://msdn.microsoft.com/en-us/library/ms187928.aspx 或 SQL Server CONVERT()函数
你可以转换你的日期在许多格式,语法很简单使用:
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
Try:
select replace(convert(varchar, getdate(), 111),'/','-');
更多关于ms sql技巧
试试下面的SQL:
select REPLACE(CONVERT(VARCHAR(24),GETDATE(),103),'/','_') + '_'+
REPLACE(CONVERT(VARCHAR(24),GETDATE(),114),':','_')
使用Microsoft SQL Server:
使用CONVERT语法:
CONVERT ( data_type [ ( length ) ] , expression [ , style ] )
例子:
SELECT CONVERT(varchar,d.dateValue,1-9)
对于样式,您可以在这里找到更多信息:MSDN - Cast和转换(Transact-SQL)。