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

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

我的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

 或者也可以使用其他的解决方案,自己未实际测试以下解决方案(下面的方法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();

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
oledbdbf文件错--“外部不是预期格式” 我的代码如下 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();
这个错误通常发生在尝试使用 Microsoft Jet 数据库引擎访问数据时,数据不符合 Jet 引擎预期格式。以下是一些可能的原因和解决方法: 1. 数据文件格式错误:请确保您正在尝试访问的数据文件格式与 Jet 引擎支持的格式兼容。例如,Jet 引擎不支持 Excel 2007 及以上版本的文件格式,您需要升级到 ACE 数据库引擎才能访问这些文件。 2. 数据文件已被损坏:如果数据文件已被损坏,则 Jet 引擎可能无法正确取数据。您可以尝试使用数据恢复工具来修复文件并再次尝试访问数据。 3. 缺少必要的库文件:如果您的计算机上缺少必要的库文件,例如 DAO360.dll、MSJet40.dll、MSJtEEN.dll 等,则 Jet 引擎可能无法正常工作。您可以尝试重新安装 Microsoft Access 或 Microsoft Office,以便安装所需的库文件。 4. 数据文件路径错误:请确保您正在尝试访问的数据文件路径是正确的,并且您有足够的权限来访问该文件。如果文件位于网络共享文件夹中,则请确保您已正确映射文件夹,并且您有足够的权限来访问文件夹中的文件。 5. 数据文件正在被其他进程占用:如果数据文件正在被其他进程占用,则 Jet 引擎可能无法访问该文件。请确保文件没有被其他应用程序或进程占用,然后再尝试访问数据。 希望这些解决方法能够帮助您解决问题。如果问题仍然存在,请尝试更换其他数据访问方法,例如使用 ODBC 或 OLE DB 接口。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值