设为首页 - 加入收藏 ASP站长网(Aspzz.Cn)- 科技、建站、经验、云计算、5G、大数据,站长网!
热搜: 数据 创业者 手机
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

从SQL中的无格式文本中解析日期

发布时间:2021-02-20 08:05 所属栏目:116 来源:网络整理
导读:我试图找出一种优雅的方法来从文本列中获取具有类似“YYYYMMDD”的数据的日期…所以我们可能会在列中看到“20060508”作为值,我希望能够从查询返回日期(2006年5月8日). 我确信如果有足够的时间我可以一起破解一些东西,但我想的方法看起来非常糟糕,我怀疑有一

我试图找出一种优雅的方法来从文本列中获取具有类似“YYYYMMDD”的数据的日期…所以我们可能会在列中看到“20060508”作为值,我希望能够从查询返回日期(2006年5月8日).

我确信如果有足够的时间我可以一起破解一些东西,但我想的方法看起来非常糟糕,我怀疑有一种方法可以在一个查询中优雅地完成.

有什么建议么?

解决方法

这已经是一个有效的日期 – ISO-8601格式 – 只需使用:
SELECT CAST('20060508' AS DATETIME)

或者:

SELECT CONVERT(DATETIME,'20060508',112)

那应该没问题!

为了获得“2006年5月8日”显示,使用日期转换样式107执行另一个转换为varchar:

SELECT CONVERT(VARCHAR(25),CAST('2006-05-08' AS DATETIME),107)

有关铸造和放大的更多信息,请参见here在MS SQL中转换

(编辑:ASP站长网)

    网友评论
    推荐文章
      热点阅读