SQL导入Excel数据时,数字中混有字符将导致数据丢失的解决办法

将EXCEL数据导出的时候如果同一列数据中既有文字,又有数字!读取时一列中要么文字丢失只剩下数字,要么数字丢失,只剩下文字,这是由第一行的数据类型决定的。出现这种问题是由于数据类型不统一造成的。
原来的连接字符串为:
string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + Path + "; Extended Properties=Excel 8.0;";
查阅资料后问题解决:
cn.ConnectionString = "Provider=Microsoft.Jet.Oledb.4.0;Data Source=" + filename + ";Extended Properties='Excel 8.0;HDR=Yes;IMEX=1;'"; //注意这里的引号哦
加的参数解释:
IMEX=1 解决数字与字符混合时,识别不正常的情况
HDR=YES 有两个值:YES/NO,表示第一行是否字段名,默认是YES,第一行是字段名

注册表里的信息需要修改,这样带能让excel不再使用前8行的内容来确定该列的类型。

注册表修改内容如下:

在 HKEY_LOCAL_MACHINE\Software\Microsoft\Jet\4.0\Engines\Excel有一个 TypeGuessRows值,预设是8,表示会先读取前8列来决定每一个栏位的型态,所以如果前8列的资料都是数字,到了第9列以后出现的文字资料都会 变成null,所以如果要解决这个问题,只要把TypeGuessRows机码值改成0,就可以解这个问题了。

Reg脚本直接修改:

Windows Registry Editor Version 5.00

[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Jet\4.0\Engines\Excel]

"TypeGuessRows"=dword:00000000
posted @ 2012-10-21 00:51  小宇飞刀  阅读(2408)  评论(0编辑  收藏  举报