天天看點

【轉】用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();