复制数据

unit UIBSQL;
interface
uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, Grids, DBGrids, DB, IBDatabase, IBCustomDataSet, IBQuery, IBSQL,
  IBUpdateSQL, DBClient, DBLocal, DBLocalI, ExtCtrls, DBCtrls, StdCtrls,
  IBTable, IBDatabaseInfo;

type
  TFIBSQL = class(TForm)
    IBSQL1: TIBSQL;
    IBDatabase1: TIBDatabase;
    IBTransaction1: TIBTransaction;
    DataSource1: TDataSource;
    DBGrid1: TDBGrid;
    IBSQL2: TIBSQL;
    Button1: TButton;
    IBTable1: TIBTable;
    IBTable2: TIBTable;
    DataSource2: TDataSource;
    DBGrid2: TDBGrid;
    procedure Button1Click(Sender: TObject);
    procedure FormCreate(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;

var
  FIBSQL: TFIBSQL;

implementation

{$R *.dfm}

procedure TFIBSQL.Button1Click(Sender: TObject);
var
  Filename : String;
  RawOutput : TIBOutputRawFile;
  RawInput : TIBInputRawFile;
begin
  IBSQL1.Sql.Text := 'Select country, currency from country';
  IBSQL2.Sql.Text := 'Insert into Newcountry (country, currency) values(:first,:second)';
  Filename := 'd:/DataFile.RAW';
  
  //将COUNTRY表中的数据输出到 d:/DataFile.RAW 文件中
  RawOutput:= TIBOutputRawFile.Create;
  try
    RawOutput.FileName := FileName;
    IBSQL1.BatchOutput(RawOutput);
  finally
    RawOutput.Free;
  end;

  //将d:/DataFile.RAW 文件中的数据输入到NEWCOUNTRY表中
  RawInput := TIBInputRawFile.Create;
  try
    RawInput.FileName := FileName;
    IBSQL2.BatchInput(RawInput);
    IBTable2.Close;
    IBTable2.Open;
  finally
    RawInput.Free;
  end;

  //事务提交
  IBSQL2.Transaction.CommitRetaining;
end;


procedure TFIBSQL.FormCreate(Sender: TObject);
begin
 IBTable1.Open;
 IBTable2.Open;
end;

end.



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值