在SSIS中将日期字符串转换为datetime

时间:2014-04-10 13:54:50

标签: datetime ssis type-conversion data-conversion

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

非常感谢!

5 个答案:

答案 0 :(得分:1)

我会使用脚本转换。然后,您可以利用具有更高优势的.NET Framework,例如DateTime.TryParse。

答案 1 :(得分:1)

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

派生列代码:

(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))

结果:

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

答案 2 :(得分:1)

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

(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))

答案 3 :(得分:0)

我编辑了源,因此将值导出为yyyy-MM-dd HH:mm:ss

因此,当它通过SSIS时,便能够通过数据转换转换工具进行本地转换

答案 4 :(得分:-1)

尝试使用(DT_TIMESTAMP)(DT_DBDATE)转换为日期,然后转换为日期时间。