使用C++中用OLEDB读dbf文件,报“外部表不是预期的格式”错误的处理

使用C++builder的ADO控件访问dbf文件,执行SQL时报错:

使用C++中用OLEDB读dbf文件,报“外部表不是预期的格式”错误的处理_第1张图片

我的connect连接字符串:

con1->ConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + strDBSrcPath + ";Extended Properties=dBASE IV;Persist Security Info=False";

解决方案:

由于dbf文件版本较高,OLEDB4.0无法打开。可先用Excel打开试一下,若打不开,就是这种情况。

所以需要先安装VFP9的OLEDB驱动vfpoledb.exe,然后修改连接字符串:

con1->ConnectionString = "Provider=VFPOLEDB.1;Data Source=" + strDBSrcPath + ";Extended Properties=dBASE IV;Persist Security Info=False";

通过 上面的解决方案解决了该问题。

如果是在connect连接时报错(即执行con1->connected = true报错) 下面的问题:未找到提供的程序,该程序可能未正确安装,也是因为缺少oledb驱动,也是安装vfpoledb.exe

使用C++中用OLEDB读dbf文件,报“外部表不是预期的格式”错误的处理_第2张图片

 或者也可以使用其他的解决方案,自己未实际测试以下解决方案(下面的方法3实际就是方面的解决方案):

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();

你可能感兴趣的:(C++Builder,C++,数据库)