字符串到DateTime SQL转换

时间:2018-04-09 17:33:29

标签: sql sql-server datetime-format

我知道这已被问过几次,但我还没有看到它询问我的具体情况。

  

如果文字采用以下格式: 2006年12月30日上午12:38 有没有办法   将其转换为实际的日期时间。我并不兴奋创建一个函数来使用子字符串等将其解析为日期

以前的开发人员开发了整个应用程序,并决定将所有日期值作为VARCHAR存储在数据库中,从而可以方便地将其更改为:2016-12-30 00:38:00Dec 30 2006 12:38AM。这使得它们不可共处(SMH)

3 个答案:

答案 0 :(得分:1)

只需使用cast()

select cast('Dec 30 2006 12:38AM' as datetime)

Here是一个SQL小提琴。

答案 1 :(得分:1)

- 请试试这个

声明@var varchar(30)='Dec 30 2006 12:38 AM' 选择转换(datetime,@ var)

答案 2 :(得分:1)

由于您正在转换字符串(总是有风险),如果2012+,我会建议尝试try_convert()。如果转换失败而不是抛出错误,Try_Convert()将返回null。

示例

Select ValidDate = try_convert(datetime,'Dec 30 2006 12:38AM')
      ,BogusDate = try_convert(datetime,'Not a Valid Date String')

返回

ValidDate                BogusDate
2006-12-30 00:38:00.000  NULL