首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在SSIS中将日期字符串转换为日期时间

在SSIS中将日期字符串转换为日期时间
EN

Stack Overflow用户
提问于 2014-04-10 21:54:50
回答 5查看 11.2K关注 0票数 2

在SSIS中将日期字符串转换为datetime时遇到问题。问题是源数据存储的日期格式为: m(m)/d(d)/yyyy,即3/8/2014,10/5/2013,12/22/2014。我已经尝试使用数据转换,但它不会工作。此外,我检查了数据质量,它们都很好-没有奇怪的字符串。有谁知道怎么修这个包裹吗?

非常感谢!

EN

回答 5

Stack Overflow用户

发布于 2014-04-15 11:21:47

为此,我将使用脚本转换。然后,您可以利用DateTime.TryParse等具有更优越功能的.NET框架。

票数 2
EN

Stack Overflow用户

发布于 2014-04-16 16:30:41

首先,您需要将Date转换为unicode字符串,现在您可以使用派生的column元素进行转换。

派生列编码:

代码语言:javascript
运行
复制
(DT_DATE)(SUBSTRING(col,FINDSTRING(col,"/",2) + 1,4) + "-" +
          SUBSTRING(col,1,FINDSTRING(col,"/",1) - 1) + "-" + 
          SUBSTRING(col,FINDSTRING(col,"/",1) + 1,FINDSTRING(col,"/",2) - FINDSTRING(col,"/",1) - 1))

结果:

代码语言:javascript
运行
复制
col         NewDateColumn
3/8/2014    2014-03-08 00:00:00.0000000
10/5/2013   2013-10-05 00:00:00.0000000
12/22/2014  2014-12-22 00:00:00.0000000
票数 1
EN

Stack Overflow用户

发布于 2017-09-06 08:28:07

这就是我使用的。它将列格式化为yyyy-MM-dd格式,然后转换为DT_DBDATE,因此如果您只需要日期字符串,则可以删除换行转换。

代码语言:javascript
运行
复制
(DT_DBDATE)(SUBSTRING(MYCOL,FINDSTRING(MYCOL,"/",2) + 1,4) + "-" + RIGHT("0" + SUBSTRING(MYCOL,1,FINDSTRING(MYCOL,"/",1) - 1),2) + "-" + RIGHT("0" + SUBSTRING(MYCOL,FINDSTRING(MYCOL,"/",1) + 1,FINDSTRING(MYCOL,"/",2) - FINDSTRING(MYCOL,"/",1) - 1),2))
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22990114

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档