我正在尝试使用 mssql2012 中的新 try_convert 功能将日期/时间/偏移字符串转换为 datetimeoffset。
字符串看起来像:2013-04-25T21:56:58.077-05:00
这是代码——我知道这种解析不起作用,所以我希望结果会达到“IS NULL”并返回“Cast Failed”。这不是发生的事情——相反,我仍然收到 Msg 241 日期转换错误。有任何想法吗?
case
when try_convert(datetimeoffset, (cast(substring(lift.PlannedLiftDateTime,1,10) + ' ' + substring(lift.PlannedLiftDateTime,12,8) + ' ' + substring(lift.PlannedLiftDateTime,20,6) as datetimeoffset))) IS NULL
then 'Cast Failed'
when ltrim(rtrim(lift.PlannedLiftDateTime)) = ''
then NULL
else
'~' + lift.PlannedLiftDateTime + '~'
end as PlannedLiftDateTime,