zoukankan      html  css  js  c++  java
  • 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
    谢祥选【小宇飞刀(xieyunc)】
  • 相关阅读:
    spring1冲刺感想与总结
    Scrum 项目7.0
    读《构造之法》8、9、10章有感
    Scrum4.0+5.0
    scrum3.0
    0512操作系统之进程调度
    Scrum 项目1.0
    团队之阅读感想
    sprint3终极演示
    0622—软件工程第一学期总结
  • 原文地址:https://www.cnblogs.com/xieyunc/p/2732846.html
Copyright © 2011-2022 走看看