日积月累—access备份恢复

本文介绍了一个简单的数据库备份和恢复流程,使用了SaveDialog和OpenDialog组件来选择文件位置及名称。备份过程会检查同名文件避免覆盖,而恢复过程则先进行当前数据库的备份以防万一。

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

procedure TForm13.cxButton1Click(Sender: TObject);       //数据库备份
var
path:string;
IsExists:Boolean;
begin
 SaveDialog1.FileName:='GDZC_'+ DateToStr(NOW);    //设置显示名称
 if SaveDialog1.Execute then
  if SaveDialog1.FileName <> '' then
   begin
   SaveDialog1.InitialDir:=ExtractFilePath(Application.ExeName); //设置路径
   path := ExtractFilePath(application.ExeName);      //程序路径
   IsExists:= FileExists(PChar(SaveDialog1.FileName+'.mdb'));
   //ShowMessage(PChar(SaveDialog1.FileName+'.mdb'));
    if IsExists then
     begin
     Application.MessageBox(PChar('已经有同名数据库【'+savedialog1.FileName+'.mdb】存在,备份失败!'
       + #13#10 + '         请更名后再试。'), '错误', MB_OK + MB_ICONSTOP);
     Exit;
     end
    else
    try
      copyfile(pchar(path+ 'gdzc.mdb'), pchar(SaveDialog1.FileName+'.mdb'), True); //true  如何存在覆盖
      Application.MessageBox(PChar('数据库已经备份为【'+savedialog1.FileName+'.mdb】'
      + #13#10#13#10+'                           备份成功!'), '提示', MB_OK);
     except
     showmessage('数据库备份失败,请重试!');
    end;
    end;
 end;

procedure TForm13.cxButton2Click(Sender: TObject);  //恢复数据
var
path:string;
begin
  if Application.MessageBox('     是否真的恢复备份数据!' + #13#10#13#10 +
    '恢复备份数据后现有数据将无法恢复。' + #13#10#13#10 + '是否真的恢复,请确认操作!', '提示',
    MB_YESNO + MB_ICONQUESTION + MB_DEFBUTTON2) = IDyes then
  begin
    OpenDialog1.InitialDir:=ExtractFilePath(application.ExeName);
  if OpenDialog1.Execute then
  if OpenDialog1.FileName <> '' then
  begin
  path := ExtractFilePath(application.ExeName);
  try
  dm.con1.Connected := false;
  RenameFile(path+'gdzc.mdb','GDZC恢复前备份.mdb');
  copyfile(pchar(OpenDialog1.FileName),pchar(path + 'GDZC.mdb'), false);
  showmessage('成功恢复数据!');
   //Application.Terminate;
  except
  showmessage('恢复失败,请重试!');
  end;
  end;
  end;


end;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值