zoukankan      html  css  js  c++  java
  • 【转】用oledb读取dbf文件报错--“外部表不是预期的格式” [

    用oledb读取dbf文件报错--“外部表不是预期的格式”
    我的代码如下
    string ole_connstring=String.Empty;
    ole_connstring = @"Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties=dBASE IV;Data Source="+FilePath;
    OleDbConnection ole_conn = new OleDbConnection(ole_connstring);
    ole_conn.Open();
    string insertsql="Insert into ["+tableName+"] (.......;
    OleDbCommand da=new OleDbCommand(insertsql,ole_conn);
    da.ExecuteNonQuery();


    DBF版本问题,用VFP9的OLEDB即可

    方法一:
    进入VFP
    USE TT
    COPY TO NEWTT TYPE FOX2X
    此方法是把表的文件版本转为新的VFP文件版本解决版本问题。

    方法二:
    升级JET 引擎到SP8,安装MDAC 2.8,到MS的网站去找

    1、VFP9的驱动是最新的,各种版本的DBF均可读出;
    2、你的连接字串是用JET的引擎,故要升级JET及MDAC;
    3、所需文件在MS的网站均有下载。

    方法三:
    安装vfpoledb.exe(VFP9的OLEDB),在项目中引用Microsoft OLE DB Provider for FoxPro 7.0 Type Library 1.0,然后使用如下代码:
    OleDbConnection con = new OleDbConnection("Provider=VFPOLEDB.1;Data Source=D:\\2006工程\\南京建设质量监督站\\资料;Collating Sequence=MACHINE");
    con.Open();               
    DataTable dtQY=new DataTable();               
    OleDbDataAdapter adapt=new OleDbDataAdapter();
    adapt.MissingSchemaAction=MissingSchemaAction.AddWithKey;        
                   
    adapt.SelectCommand = new OleDbCommand("select * from 200512.DBF",con);
    adapt.Fill(dtQY);       
    adapt.Dispose();
    DataView dvQY = dtQY.DefaultView;
    dtQY.Dispose();
    con.Close();

    from:http://xdmwc.blog.hexun.com/12924654_d.html 

  • 相关阅读:
    统计脚本代码行数
    expr算术运算
    lsof命令
    测试当前机器可以创建多少线程
    守护进程写日志
    文件描述符fd,struct files_struct
    linux查看反汇编
    信号补充
    Windows10获取VS管理员权限总是很烦人
    asp.net中的Filter类型其实是被当作单例的
  • 原文地址:https://www.cnblogs.com/SummerRain/p/2624960.html
Copyright © 2011-2022 走看看