dbf 连接字符串问题 .

本文详细介绍了解决FoxPro数据库连接错误问题的方法,通过修改连接字符串中的SourceDB路径,确保了数据库连接的正确性和稳定性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

解决ERROR [42S02] [Microsoft][ODBC Visual FoxPro Driver]File 'xxx.dbf' does not exist.
的问题:
是因为连接FoxPro的连接字符串存在问题
"Driver={Microsoft Visual FoxPro

Driver};SourceType=DBF;SourceDB=c:/TestTzm/Test.dbf";Exclusive=No;BackgroundFetch=No;";
这个连接串是错误的.
在访问的时候,连接会自动查找路径下的dbf文件或者创建dbf文件,所以不需要dbf文件
正确的连接如下:
"Driver={Microsoft Visual FoxPro

Driver};SourceType=DBF;SourceDB=c:/TestTzm";Exclusive=No;BackgroundFetch=No;";
注意SourceDB=c:/TestTzm,这里只要写路径就可以了,不需要添加Test.dbf文件

 

 

procedure TForm1.Button1Click(Sender: TObject);
var
  db_file_tmp:string;
begin
  db_file_tmp :=  'C:\Users\xy\Desktop\38扫描数据201104271024-2\';
  ADOConnection1.Close;
  ADOConnection1.ConnectionString:='Provider=MSDASQL.1;Persist Security Info=False;Extended Properties="Driver={Microsoft FoxPro VFP Driver (*.dbf)};UID=;'
                                +'SourceDB='+db_file_tmp+';SourceType=DBF;Exclusive=No;BackgroundFetch=Yes;Collate=Machine;"';

  ADOConnection1.LoginPrompt := False;
  try
    try
      ADOConnection1.connected := true;
    except on E: Exception do
      begin
        showmessage('数据库连接失败,原因:' + #13#10 + E.Message);
        abort;
      end;
    end;
  finally
   ;
  end;


  //

  ADOQuery1.Close;
  ADOQuery1.SQL.Text := 'select * from kddzb.dbf'   ;
  ADOQuery1.Open;
  ADOQuery1.First;
  ShowMessage(inttostr(ADOQuery1.recordcount));
end;


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值