如何在 SQL Server 中将字符串转换为日期时间?

Posted

技术标签:

【中文标题】如何在 SQL Server 中将字符串转换为日期时间?【英文标题】:How to convert a string into datetime in SQL Server? 【发布时间】:2021-04-23 15:53:19 【问题描述】:

我正在编写一个 SQL 查询来将字符串转换为日期时间:

SELECT CAST('2017-04-07.15-23-44' AS datetime)

当我将其转换为日期时间时出现错误

varchar 数据类型转换为 datetime 数据类型导致值超出范围。

【问题讨论】:

那是因为它没有正确格式化以进行转换。 你为什么首先使用字符串而不是日期?修复无效的字段或参数类型比掩盖它要好得多。此外,我怀疑地球上任何国家都使用这种日期和时间格式。 SQL Server 怎么能猜到这个字符串的含义? @PanagiotisKanavos 实际上我是从文件名中得到的。 那是什么名字?同样,任何国家都没有使用这种格式。 SQL Server 怎么可能猜到它的意思?如果要解析这种自定义格式,则必须为其编写代码。 将数据插入数据库之前解析这样的字符串要容易得多 docs.microsoft.com/en-us/sql/t-sql/functions/… 概述了支持的格式 - 即使这样您也必须指定要转换的格式。 【参考方案1】:

使用. 作为分隔符拆分字符串,并在第二部分将所有'-' 替换为':'。 再次连接这两个部分,然后将其转换为DATETIME

DECLARE @d VARCHAR(20) = '2017-04-07.15-23-44';

SELECT CAST(LEFT(@d, CHARINDEX('.', @d) - 1) + ' ' +
            REPLACE(SUBSTRING(@d, CHARINDEX('.', @d) + 1, LEN(@d)), '-', ':')
            AS datetime
           )

请参阅demo。

【讨论】:

【参考方案2】:

您可以尝试以下方法将其格式化为 ISO 日期

declare @date varchar(20)='2017-04-07.15-23-44' 
select Cast(Replace(Replace(Stuff(Stuff(@date,14,1,':'),17,1,':'),'-',''),'.',' ')  as datetime)

【讨论】:

以上是关于如何在 SQL Server 中将字符串转换为日期时间?的主要内容,如果未能解决你的问题,请参考以下文章

在函数 SQL Server 中将字符串转换为日期时间

在 MS SQL Server 中将字符串转换为日期时间

在 PHP Laravel 中的 SQL Server 中将字符串转换为日期数据类型

在 C# 中将十六进制值从 SQL Server 转换为日期时间

在 SQL Server 中将 varchar 转换为 datetime [重复]

SQL Server 将字符串转换为日期时间