亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? sysbackup.pas

?? delphi開發的中國移動大客戶管理系統,后臺數據庫為oracle
?? PAS
字號:
//------------------------------------------------------------
//      作者:曾慶順
//      模塊:系統數據備份窗口
//      時間:2002.09.17
//      功能介紹:
//-----------------------------------------------------------
unit sysbackup;

interface

uses
  Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
  StdCtrls, ExtCtrls, DBTables, Db, Buttons,FileCtrl;

type
  TSysBackFrm = class(TForm)
    Panel1: TPanel;
    GroupBox1: TGroupBox;
    RB_DB: TRadioButton;
    RB_DBF: TRadioButton;
    RB_TXT: TRadioButton;
    Table1: TTable;
    Table2: TTable;
    BatchMove1: TBatchMove;
    BitBtn1: TBitBtn;
    BitBtn2: TBitBtn;
    Label1: TLabel;
    Label2: TLabel;
    CB_Delete: TCheckBox;
    procedure FormCreate(Sender: TObject);
    procedure BitBtn1Click(Sender: TObject);
  private
    { Private declarations }
    
    FDir:string;
    Function IsHaveDcid(pTable:TTable;pDcid:string):Boolean;
    Function IsHaveBlob(pTable:TTable):Boolean;
    Function ExecQuery(PQuery:TQuery;PSql:string):Boolean;
    //得到數據庫服務器日期
    Function GetDbServerDate(DBName:string):string;overload;
  public
    { Public declarations }
  end;

var
  SysBackFrm: TSysBackFrm;

implementation

{$R *.DFM}
uses xt_sjbf_frm_main;

procedure TSysBackFrm.BitBtn1Click(Sender: TObject);
var FTName:string;
    fsql:string;
begin
   xt_sjbf_main.qry_TB_XTGL_FACB.DisableControls;

   if RB_TXT.Checked then
   begin
     xt_sjbf_main.qry_TB_XTGL_FACB.First;
     while not xt_sjbf_main.qry_TB_XTGL_FACB.Eof do
     begin
        Table1.close;
        Table1.TableName:=xt_sjbf_main.qry_TB_XTGL_FACB.fieldbyname('BYWM').asstring;
        if IsHaveBlob(Table1) then
        begin
           if Application.MessageBox('要備份的表存在Blob或Memo字段,'+#13+' 不能'+
             '用文本的方式備份,'+#13+'  否則該表將不做備份,'+#13+'   是否選擇其他方'+
             '式?','警告',MB_OKCANCEL+MB_ICONSTOP) =ID_OK then exit;
           break;
        end;
        xt_sjbf_main.qry_TB_XTGL_FACB.Next;
     end;
   end;

   //設置備份方式為拷貝
   BatchMove1.Mode:=batCopy;
   table2.DatabaseName:=FDir;
   //計算要備份的表的個數
   FSql:='select count(*) from T_XTGL_FACB where FABH ='''+xt_sjbf_main.Edit_fabh.Text+'''';
   xt_sjbf_main.Query.close;
   xt_sjbf_main.Query.sql.Clear;
   
   if xt_sjbf_main.qry_TB_XTGL_FACB.Filtered then
     fsql:=fsql+ ' and ('+ xt_sjbf_main.qry_TB_XTGL_FACB.Filter+')';
   xt_sjbf_main.Query.sql.Add(fsql);

   xt_sjbf_main.Query.open;
   xt_sjbf_main.Query.First;

   //正式開始備份
   xt_sjbf_main.qry_TB_XTGL_FACB.First;
   while not xt_sjbf_main.qry_TB_XTGL_FACB.Eof do
   begin
      FTName:=xt_sjbf_main.qry_TB_XTGL_FACB.fieldbyname('BYWM').asstring;
      Table1.close;
      Table1.TableName:=FTName;
      table1.Filter:='';
      table1.Filtered:=false;
      //刪除數據時用
      fsql:='delete from '+FTName;
      //if IsHaveDcid(Table1,'DCID') then
      //begin
        //table1.Filter:='DCID='''+FCurrentDcid+'''';
        table1.Filtered:=true;
        //如果有DCID 則刪除數據時要過濾
        fsql:='delete from ' + FTName ;
      //end;

      Label2.Caption:=xt_sjbf_main.qry_TB_XTGL_FACB.fieldbyname('BZWM').asstring;
      self.update;

      Table2.close;
      if RB_DB.Checked then
      begin
        table2.TableName:=FTName+'.db';
        table2.TableType:=ttParadox;
      end
      else if RB_DBF.Checked then
      begin
        table2.TableName:=FTName+'.dbf';
        table2.TableType:=ttDBase;
      end
      else
      begin
        if IsHaveBlob(Table1) then
        begin
           xt_sjbf_main.qry_TB_XTGL_FACB.Next;
           continue;
        end;
        table2.TableName:=FTName+'.txt';
        table2.TableType:=ttASCII;
      end;
      try
         if table1.Active then table1.Active:=false;
         if table2.Active then table2.Active:=false;
         BatchMove1.Execute;
      except
        xt_sjbf_main.qry_TB_XTGL_FACB.EnableControls;
        Application.MessageBox('備份表數據失敗!','警告',MB_OK+MB_ICONSTOP);
        close;
        exit;
      end;
      //如果選中則刪除數據
      if CB_Delete.Checked then
      begin
        ExecQuery(xt_sjbf_main.Query,fsql);
      end;
      xt_sjbf_main.qry_TB_XTGL_FACB.Next;
      //

   end;
   xt_sjbf_main.qry_TB_XTGL_FACB.EnableControls;
   Application.MessageBox('備份表數據成功!','警告',MB_OK+MB_ICONEXCLAMATION);
   close;
end;

Function TSysBackFrm.IsHaveDcid(pTable:TTable;pDcid:string):Boolean;
var i:integer;
begin
    result:=false;
    if not pTable.Active then
    try
       pTable.Active:=true;
    except
       exit;
    end;
    for i:=0 to pTable.FieldCount - 1 do
    begin
      if pTable.Fields[i].FieldName = pDcid then
      begin
        result:=true;
        break;
      end;
    end;
end;
Function TSysBackFrm.IsHaveBlob(pTable:TTable):Boolean;
var i:integer;
begin
    result:=false;
    if not pTable.Active then
    try
       pTable.Active:=true;
    except
       result:=true;
       exit;
    end;
    for i:=0 to pTable.FieldCount - 1 do
    begin
      if (pTable.Fields[i].DataType=ftMemo) or (pTable.Fields[i].DataType=ftBlob) then
      begin
        result:=true;
        break;
      end;
    end;
end;
procedure TSysBackFrm.FormCreate(Sender: TObject);
begin
  //數據備份在當前目錄下\data子目錄
  Label2.Caption:='';
  FDir:=ExtractFilePath(ParamStr(0))+'data\'+GetDbServerDate('db_vipdl');
  if not DirectoryExists(FDir) then ForceDirectories(FDir);
  
end;



function TSysBackFrm.ExecQuery(PQuery: TQuery; PSql: string): Boolean;
begin
  Result:=true;
  PQuery.close;
  PQuery.sql.Clear;
  PQuery.Filtered:=false;
  PQuery.sql.add(PSql);
  try
    PQuery.ExecSQL;
  except
    Result:=false;
  end;
end;

function TSysBackFrm.GetDbServerDate(DBName: string): string;
var query:TQuery;
    Present: TDateTime;
    Year, Month, Day: Word;
    str:string;
begin
  try
      query:=TQuery.Create(nil);
  except
      exit;
  end;
  query.DatabaseName:=DBname;
  query.close;
  query.sql.Clear;
  query.sql.Add('select distinct sysdate from dual');
  try
     query.open;
  except
     exit;
  end;
  query.First;
  Present:=Query.Fields[0].AsDateTime;
  DecodeDate(Present, Year, Month, Day);
  str:=inttostr(year);
  if month<10 then str:=str+'0'+inttostr(month)
  else str:=str+inttostr(month);
  if day<10 then str:=str+'0'+inttostr(day)
  else str:=str+inttostr(day);
  result:=str;
  query.free;
end;

end.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲激情第一区| 亚洲自拍偷拍av| 7777精品久久久大香线蕉| 一本一道综合狠狠老| 一本一道久久a久久精品综合蜜臀| 高清不卡一区二区在线| 国产白丝网站精品污在线入口| 国产精品自在在线| 成人国产精品免费| 99久久99久久免费精品蜜臀| 99视频在线精品| 色综合久久中文字幕| 在线观看不卡一区| 91麻豆精品国产91久久久久| 7777精品伊人久久久大香线蕉超级流畅| 欧美视频在线播放| 欧美一区二区在线视频| 精品少妇一区二区三区免费观看| 欧美xfplay| 国产精品国产三级国产aⅴ原创 | 久久国产精品无码网站| 狠狠久久亚洲欧美| caoporen国产精品视频| 91国产丝袜在线播放| 日韩一区二区麻豆国产| 精品国产sm最大网站免费看| 中文幕一区二区三区久久蜜桃| 亚洲精品日韩专区silk| 青青草国产成人99久久| 国产成人激情av| 欧美日本国产视频| 久久老女人爱爱| 一区二区在线观看视频在线观看| 日韩不卡一二三区| 国产高清精品久久久久| 欧美色图12p| 久久久久九九视频| 午夜视频久久久久久| 国产精品一区在线| 欧美日韩国产综合久久| 久久奇米777| 香蕉加勒比综合久久| 国产精品亚洲专一区二区三区| 欧美亚洲综合色| 国产欧美日韩三区| 肉色丝袜一区二区| 成年人网站91| 精品福利一区二区三区| 亚洲日本在线看| 国产成人在线看| 91精品国产麻豆国产自产在线| 国产精品免费丝袜| 国产中文一区二区三区| 7777精品伊人久久久大香线蕉完整版| 18欧美亚洲精品| 国产成人av一区二区三区在线 | 久久综合999| 亚洲地区一二三色| 成人综合婷婷国产精品久久免费| 欧美美女一区二区三区| 综合久久久久久| 不卡视频在线看| 日本一区二区成人| 激情久久久久久久久久久久久久久久| 欧美亚洲国产一区二区三区va| 国产精品青草综合久久久久99| 蜜臀久久99精品久久久画质超高清| 91国产视频在线观看| 中文字幕亚洲视频| 成人免费av资源| 国产片一区二区三区| 国产成人av电影在线| 久久免费看少妇高潮| 激情小说亚洲一区| 精品国产三级电影在线观看| 精品一区二区三区视频在线观看 | 久久99在线观看| 欧美一区二区精品| 久久se这里有精品| 精品国产自在久精品国产| 蜜桃视频在线一区| wwwwxxxxx欧美| 国产精品影视网| 国产精品美女久久久久久久| 成人激情动漫在线观看| 亚洲手机成人高清视频| 99re成人精品视频| 亚洲成a人片在线观看中文| 欧美日韩一区精品| 秋霞国产午夜精品免费视频 | 精品亚洲成av人在线观看| 欧美成人乱码一区二区三区| 精品亚洲免费视频| 国产欧美一区二区精品久导航| 国产精选一区二区三区| 国产精品国产三级国产aⅴ入口 | 亚洲成av人影院| 欧美一区二视频| 国产一区不卡视频| 亚洲欧美一区二区三区极速播放| 色综合婷婷久久| 久久精品免费观看| 欧美激情一区二区三区蜜桃视频| 不卡的av电影| 日韩在线播放一区二区| 久久久久免费观看| 99久久精品国产一区二区三区| 一区二区不卡在线视频 午夜欧美不卡在| 欧美性受xxxx黑人xyx性爽| 蜜臀av国产精品久久久久| 日本一区二区三区免费乱视频| 91福利在线观看| 国内精品免费**视频| 亚洲黄色免费网站| 久久综合网色—综合色88| 91免费版在线| 国产在线播精品第三| 亚洲国产成人精品视频| 国产欧美精品一区二区色综合 | 美女www一区二区| 亚洲视频电影在线| 26uuu久久天堂性欧美| 欧美三级欧美一级| 99re在线视频这里只有精品| 精品一区中文字幕| 亚洲成av人**亚洲成av**| 国产精品久久久久影院老司| 日韩欧美国产一区在线观看| 在线观看日韩一区| 成人午夜激情片| 国产精品一区在线观看乱码| 人人精品人人爱| 日韩国产欧美在线视频| 亚洲视频一二区| 久久久精品天堂| 日韩欧美国产三级电影视频| 欧美日韩中文另类| 99久久精品99国产精品| 国产精品123| 久久se精品一区二区| 日本伊人午夜精品| 五月综合激情婷婷六月色窝| 亚洲欧美一区二区三区极速播放| 国产欧美精品一区| 国产色婷婷亚洲99精品小说| 久久毛片高清国产| 久久综合狠狠综合| 久久这里只精品最新地址| 欧美v国产在线一区二区三区| 7777精品伊人久久久大香线蕉| 欧美日韩精品一区二区| 欧美视频中文一区二区三区在线观看 | 亚洲免费观看视频| 亚洲人成精品久久久久| 国产精品久久久久影视| 欧美激情在线一区二区| 国产精品理论在线观看| 国产三级精品在线| 国产精品嫩草影院av蜜臀| 中文字幕在线观看不卡视频| 国产精品国产精品国产专区不蜜 | 日本成人在线一区| 久88久久88久久久| 精品午夜久久福利影院| 国产成人自拍网| 成人av网站在线观看免费| 成人avav影音| 91国偷自产一区二区三区成为亚洲经典| 99精品国产91久久久久久| 日本乱人伦aⅴ精品| 欧美日本在线看| 91精品国产欧美一区二区18| 337p日本欧洲亚洲大胆精品| 国产日韩欧美在线一区| 亚洲精品国产一区二区三区四区在线 | 久久一夜天堂av一区二区三区| 欧美精品一区二区三区蜜臀| 久久久91精品国产一区二区三区| 国产三级精品在线| 一区二区三区精品在线| 蜜臀99久久精品久久久久久软件| 国产馆精品极品| 欧美性猛交xxxxxx富婆| 日韩欧美一级二级三级| 日韩毛片在线免费观看| 日韩在线卡一卡二| 大桥未久av一区二区三区中文| 在线观看日韩一区| 国产亚洲婷婷免费| 日韩av在线免费观看不卡| 国产高清无密码一区二区三区| 欧美性生活一区| 日韩一区二区三区视频在线| 国产精品久久三区| 日本不卡的三区四区五区| 成人av小说网| 日韩欧美综合一区| 亚洲日本韩国一区| 激情小说欧美图片| 欧美日韩国产区一|