• 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)】
  • 相关阅读:
    UGUI血条跟随
    unity组件路径自动生成
    双摄像机使用
    Unity 属性雷达图
    unity UGUI UI跟随
    Unity中实现人物平滑转身
    游戏摇杆
    IIS下载无后缀文件的设置
    convert svn repo to git
    Discovery and auto register
  • 原文地址:https://www.cnblogs.com/xieyunc/p/2732846.html
Copyright © 2020-2023  润新知