SQL导入Excel字段超255字符问题解决

最近在做一个项目时需要导入Excel数据到SQL Server中,之前导入Excel很多次都比较顺利,这次遇到个问题从来没见过,花了近两个小时试来试去,最后终于从网上找个方法解决了,是长度超过255个字符了,但奇怪的是只导入一条数据是没有问题的,这条超过255的数据和其它短数据放在一起导入就出问题,在此记录。

问题内容:

[Excel 源 [1]] 错误: 输出“Excel 源输出”(9) 上的 输出列“Description 3”(546) 出错。返回的列状态是:“文本被截断,或者一个或多个字符在目标代码页中没有匹配项。”。

问题如图:

20150818211303

问题原因:

Excel中某些记录字段长度超过255个字符(并且这条记录是第8条之后,为什么说第8条之后呢,后面说。)

解决方案:

1、导入时会先检测最大长度,是通过检测Excel表中前8条中的最大值,这就是上面为什么说第8条,并且为什么只导入一条也没问题。

2、通过修改注册表的方式将检测前8条改为检测所有行。

3、注册表修改:

Jet引擎:HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Jet\4.0\Engines\Excel
ACE引擎:HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Office\12.0\Access Connectivity Engine\Engines\Excel
64位系统:HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Microsoft\Jet\4.0\Engines\Excel

附注册表导入文件下载:http://bbs.vcoo.cc/show-181-1-1.html

找到上面键,将下面项TypeGuessRows的值改为0即可。原因是驱动默认情况下根据列的前8行数据判定列长度,修改为0后需要检查整列数据来判定列长度。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值