如何将datetime
值转换成yyyymmddhhmmss
?
例如来自2014-04-17 13:55:12
致20140417135512
从SQL Server Version 2012开始,您可以使用:
SELECT format(getdate(),'yyyyMMddHHmmssffff')
这似乎有效:
declare @d datetime
set @d = '2014-04-17 13:55:12'
select replace(convert(varchar(8), @d, 112)+convert(varchar(8), @d, 114), ':','')
结果:
20140417135512
SELECT REPLACE(REPLACE(REPLACE(CONVERT(VARCHAR(19), CONVERT(DATETIME, getdate(), 112), 126), '-', ''), 'T', ''), ':', '')
FORMAT()
比CONVERT()
慢。这个答案稍微好于@jpx的答案,因为它只对日期的时间部分进行了替换。
112 = yyyymmdd - no format change needed
108 = hh:mm:ss - remove :
SELECT CONVERT(VARCHAR, GETDATE(), 112) +
REPLACE(CONVERT(VARCHAR, GETDATE(), 108), ':', '')
我用google搜索的另一个选项,但包含几个替换...
SELECT REPLACE(REPLACE(REPLACE(CONVERT(VARCHAR(19), CONVERT(DATETIME, getdate(), 112), 126), '-', ''), 'T', ''), ':', '')
此查询是将DateTimeOffset
转换为带有Offset的格式yyyyMMddhhss
。我已经从数据中替换了连字符colon(:), period(.)
,并保留了连字符以便从DateTime
中分离出Offset。
SELECT REPLACE(SUBSTRING(CONVERT(VARCHAR(33),SYSDATETIMEOFFSET(),126), 1, 8), '-', '') +
SUBSTRING(REPLACE(REPLACE(REPLACE(CONVERT(VARCHAR(33), SYSDATETIMEOFFSET(), 126),'T',''),'.',''),':',''),9,DATALENGTH(CONVERT(VARCHAR(33), SYSDATETIMEOFFSET(), 126)))
这也有效
SELECT replace(replace(replace(convert(varchar, getdate(), 120),':',''),'-',''),' ','')
20090320093349
SELECT CONVERT(VARCHAR,@date,112) +
LEFT(REPLACE(CONVERT(VARCHAR,@date,114),':',''),6)