access 创建,覆盖,连接

 

 

 

 

function   TForm1.GetTempPathFileName():string;//取得临时文件名
var
  SPath,SFile:array   [0..254]   of   char;
  begin
    GetTempPath(254,sPath);
    GetTempFileName(sPath,'~SM',0,SFile);
    result:=SFile;
    DeleteFile(PChar(result));

end;
function TForm1.create_mdb(const fnames:string):boolean;  //创建access数据库,如果存在这创建失败
var
   yuanname:string;
    CreateAccess:OleVariant;
begin
     yuanname:=GetTempPathFileName;
 try
        CreateAccess:=CreateOleObject('ADOX.Catalog');
        CreateAccess.Create(format('Provider=Microsoft.Jet.OLEDB.4.0;Data Source=%s',[yuanname]));
        result:=copyfile(pchar(yuanname),Pchar(Fnames),true);
        DeleteFile(yuanname);
      except
          result:=false;
     end;
 end;
function  TForm1.CompactDatabase(AFileName:string):boolean; //压缩与修复数据库,覆盖源文件
var
    STempFileName:string;
    vJE:OleVariant;
  begin
    STempFileName:=GetTempPathFileName;
    try
        vJE:=CreateOleObject('JRO.JetEngine');
        vJE.CompactDatabase(format('Provider=Microsoft.Jet.OLEDB.4.0;Data Source=%s',[AFileName]),
                format('Provider=Microsoft.Jet.OLEDB.4.0;Data Source=%s',[STempFileName]));
        result:=CopyFile(PChar(STempFileName),PChar(AFileName),false);
        DeleteFile(STempFileName);
    except
        result:=false;
    end;
end;
procedure TForm1.conning_mdb(sql:string); //数据库连接
var
        strcon,str_sql:string;
begin
          strcon:='Provider=Microsoft.Jet.OLEDB.4.0;Data Source='+fname;
          ADO.ConnectionString:=strcon;
          if  not ADO.connected  then
           begin
            ADO.connected:=true;
           end;
          adoquery1.connection:=ADO;
          adoquery1.close;
          adoquery1.SQL.Clear;
          str_sql := sql;
          adoquery1.sql.add(str_sql);
          adoquery1.ExecSQL;
          ado.Close;
end;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值