数据库备份与恢复

unit UStore;
interface
uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls, IBServices;
type
  TFRestore = class(TForm)
    IBBackupService1: TIBBackupService;
    IBRestoreService1: TIBRestoreService;
    Button1: TButton;
    Memo1: TMemo;
    Button2: TButton;
    Memo2: TMemo;
    procedure Button1Click(Sender: TObject);
    procedure Button2Click(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;

var
  FRestore: TFRestore;

implementation

{$R *.dfm}

procedure TFRestore.Button1Click(Sender: TObject);
begin
//数据库备份
 with IBBackupService1 do
  begin
    ServerName := 'employee';
    LoginPrompt := False;
    Params.Add('user_name=sysdba');
    Params.Add('password=masterkey');
    Active := True;
    try
      Verbose := True;
      Options := [NonTransportable, IgnoreLimbo];
      //指定数据库源文件 ,设置为特定的数据库文件
      DatabaseName := 'G:/malin/employee.gdb';
      //指定备份文件
      BackupFile.Add('C:/temp/employee1.gbk');
       //启动服务
      ServiceStart;
      While not Eof do
      //在Memo组件中显示备份信息
        Memo1.Lines.Add(GetNextLine);
    finally
      Active := False;
    end;
  end;
end;

procedure TFRestore.Button2Click(Sender: TObject);
begin
//从备份文件中恢复数据库
with IBRestoreService1 do
  begin
    ServerName := 'Poulet';
    LoginPrompt := False;
    Params.Add('user_name=sysdba');
    Params.Add('password=masterkey');
    Active := True;
    try
      Verbose := True;
      Options := [Replace, UseAllSpace];
      PageBuffers := 3000;
      PageSize := 4096;
      //要恢复的数据库
      DatabaseName.Add('G:/malin/employee1.gdb');
      //指定备份文件
      BackupFile.Add('C:/temp/employee1.gbk');
      ServiceStart;
      While not Eof do
      //在Memo组件中显示恢复信息
        Memo2.Lines.Add(GetNextLine);
    finally
      Active := False;
    end;
  end;
end;

end.


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值