当前位置:  开发笔记 > 数据库 > 正文

SSIS Excel导入强制不正确的列类型

如何解决《SSISExcel导入强制不正确的列类型》经验,为你挑选了5个好方法。

我正在尝试使用SSIS将电子表格导入我们的数据库.出于某种原因,SSIS想要相信其中两列是Double类型,当它们包含字符数据时.我已经尝试将列重新映射为nvarchar(255),但它仍然不想选择它认为是双倍的数据,因为它中有字符.如果我尝试编辑SSIS包并更改Excel源中的列类型,它将不允许我更改错误输出中的列类型,如果常规输出和错误输出列不比赛.

为什么SSIS坚持认为这些列是Double?我怎么能强迫它实现这些字符串呢?为什么微软的所有东西都不能正常工作?

编辑:我发现了这个:http://support.microsoft.com/kb/236605

我对数据进行了排序,以便混合数据类型位于顶部,然后猜测:问题发生了逆转.它不再导入字符数据,而是停止导入纯数字数据.显然有人不认为12345可以表示为字符串......



1> James..:

我以前见过这个问题,这是Excel的问题而不是SSIS.Excel会对前几行进行采样,然后即使您明确将其设置为文本也会推断出数据类型.您需要做的是将其放入SSIS包中的Excel文件连接字符串中.该指令告诉Excel列中包含混合数据类型,并提示它在确定列是数字类型之前进行额外检查,而事实上并非如此.

;Extended Properties="IMEX=1"

它应该适用于此(在大多数情况下).更安全的做法是将Excel数据导出到制表符分隔文本并使用SSIS导入它.

http://blogs.acceleration.net/ryan/archive/2005/01/11/477.aspx



2> Joe L...:

您可以将列数据转换(即强制)为文本...尝试此操作(注意:这些说明基于Excel 2007)...

以下步骤应强制Excel将列视为文本:

使用Excel打开电子表格.

通过单击列标题选择包含"主要数字数据"的整个列.

单击功能区菜单上的"数据"选项卡.

选择文本到列.这将打开"将文本转换为列向导".

- 在第1步:单击"下一步"

- 在第2步:单击"下一步"

- 在第3步:选择"文本",然后单击"完成"

保存Excel工作表.

使用SQL Server 2005导入数据向导重试导入.

此外,这是另一个问题的链接,其中包含其他答案:

导入数据向导不喜欢数据类型我选择列


最好的,没有废话的解决方案.为我工作很棒,导入到SQL 2014.问题是一些邮政编码被格式化为99999,其他邮编为99999-9999,还有一些是加拿大或英国格式!这种方法处理得很好.注意:需要一次完成1列,例如邮政编码,电话,传真.

3> RolandTumble..:

未在接受的答案中提到的一件事是,"IMEX = 1"参数已经去里面的引用部分:

...;Extended Properties="...";



4> Joost..:

; IMEX = 1; 并不总是有效... Excel中混合数据类型的所有内容: Excel列中的混合数据类型

在此输入图像描述



5> 小智..:

另一种解决方法是使用顶部的字符数据对电子表格进行排序,从而使Excel将列视为字符串,并导入所有内容.

推荐阅读
手机用户2402851335
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有