亚洲欧美第一页_禁久久精品乱码_粉嫩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影院在线| 欧美一区二区三区爱爱| 亚洲a一区二区| 在线不卡中文字幕播放| 首页综合国产亚洲丝袜| 日韩欧美国产一区在线观看| 麻豆免费精品视频| 久久精品视频一区二区三区| 国产·精品毛片| 亚洲天堂av一区| 91免费小视频| 久色婷婷小香蕉久久| 久久久精品人体av艺术| 波多野结衣视频一区| 国产在线国偷精品免费看| 久久久久国产精品厨房| 91在线国产福利| 香蕉成人啪国产精品视频综合网 | 中文欧美字幕免费| 在线亚洲人成电影网站色www| 亚洲成人在线观看视频| 久久久综合视频| 国产午夜精品理论片a级大结局| 一区二区三区中文字幕电影| 高清免费成人av| 日韩一区二区视频在线观看| 亚洲成av人片在线观看| 成人在线视频首页| 久久99精品久久只有精品| voyeur盗摄精品| 久久久影院官网| 激情偷乱视频一区二区三区| 欧美日韩三级一区二区| 一区二区三区视频在线看| 亚洲乱码一区二区三区在线观看| 国产精品正在播放| 国产亚洲一区二区在线观看| 久久超碰97中文字幕| 欧美日韩激情一区二区| 亚洲自拍偷拍综合| 国产一区二区在线免费观看| 欧美日韩精品一区二区三区蜜桃 | 日本伊人色综合网| hitomi一区二区三区精品| 51午夜精品国产| 亚洲国产日韩av| 日本高清不卡视频| 一区二区三区不卡在线观看| 欧洲激情一区二区| 午夜精品在线看| 久久久91精品国产一区二区精品| 国产成人综合视频| 亚洲精品成人少妇| 欧美色男人天堂| 热久久国产精品| 日韩一区二区三区视频在线 | 欧美精品久久一区| 美国毛片一区二区三区| 精品久久99ma| 国内精品免费**视频| 国产无遮挡一区二区三区毛片日本| 国产精品影音先锋| 中文字幕一区二区三区蜜月| 丁香婷婷综合五月| 国产精品动漫网站| 欧美在线三级电影| 懂色av一区二区在线播放| 亚洲一级二级三级| 久久免费午夜影院| 欧美一区二区三区在线电影| 高清国产一区二区三区| 经典三级视频一区| 久久久久9999亚洲精品| av在线不卡电影| 国产在线不卡视频| 日韩精品电影一区亚洲| 一区av在线播放| 国产三级精品三级在线专区| 欧美第一区第二区| av资源网一区| 亚洲地区一二三色| 国产精品美女一区二区三区| 欧美一区二区黄色| 91黄视频在线| 在线观看日韩电影| 成人国产精品免费观看动漫| 麻豆免费精品视频| 日本不卡的三区四区五区| 夜色激情一区二区| 亚洲视频一区在线| 国产精品天美传媒沈樵| 欧美精品 日韩| 91在线观看污| 成人精品一区二区三区中文字幕 | 日韩欧美中文字幕制服| 欧美日韩视频在线第一区 | 久久品道一品道久久精品| 91.成人天堂一区| 色av成人天堂桃色av| 在线观看日韩国产| aaa亚洲精品| 91天堂素人约啪| 成人av电影在线观看| 国产精品综合一区二区| 国产精品66部| 成人黄色777网| 国产成人啪午夜精品网站男同| 亚瑟在线精品视频| 蜜桃久久av一区| 国内久久精品视频| 激情偷乱视频一区二区三区| 久久精品国产99久久6| 久久9热精品视频| 国产精品一级片| 久久精品av麻豆的观看方式| 国产一区二区在线观看视频| 国产在线播精品第三| 国产91对白在线观看九色| 日本久久精品电影| 91精品国产aⅴ一区二区| 中日韩免费视频中文字幕| 亚洲视频免费观看| 亚洲成a人v欧美综合天堂下载| 国产精品一区二区果冻传媒| 成人免费视频视频| 欧美视频在线观看一区二区| 久久久久久夜精品精品免费| 亚洲免费观看高清完整版在线| 亚洲国产视频在线| 成人h动漫精品一区二区| 欧美视频在线一区二区三区 | av激情亚洲男人天堂| 欧美日韩视频在线观看一区二区三区| 国产亚洲一区二区在线观看| 国产精品久久久久久久午夜片 | 中文字幕不卡的av| 奇米影视一区二区三区| 国产乱一区二区| 色婷婷综合久久久| 国产精品久久久久aaaa樱花| 美国一区二区三区在线播放| 国产91丝袜在线观看| 欧美日韩一级片在线观看| 日本一区二区三区电影| 极品少妇xxxx精品少妇偷拍| 欧美日韩在线综合| 精品成a人在线观看| 国产综合色视频| 精品99999| 午夜欧美视频在线观看| 色婷婷综合久久久中文一区二区| 国产精品初高中害羞小美女文 | 东方aⅴ免费观看久久av| 中文一区二区在线观看| 一区二区三区**美女毛片| 欧美日韩午夜影院| 国产精品久久精品日日| 福利电影一区二区三区| 久久品道一品道久久精品| 国产尤物一区二区| 99国产欧美久久久精品| 亚洲欧洲日韩av| 在线视频欧美区| 亚洲视频狠狠干| 色香蕉久久蜜桃| 日韩中文字幕1| 欧美一区二区美女| 国产伦精品一区二区三区免费 | 日韩有码一区二区三区| 精品伦理精品一区| 国产在线精品一区二区夜色| 中文字幕不卡一区| 国产精品一二一区| 美女视频一区在线观看| 国产网站一区二区三区| 成人午夜视频免费看| 亚洲成人午夜影院| 久久午夜电影网| 波多野结衣中文字幕一区 | 亚洲男同性视频| 在线播放视频一区| 成人免费视频视频| 天天爽夜夜爽夜夜爽精品视频| 欧美草草影院在线视频| 97久久精品人人做人人爽50路| 亚洲18女电影在线观看| 久久影院视频免费| 欧美性色综合网| 国产精品亚洲一区二区三区妖精| 亚洲视频免费观看| 日韩欧美国产一二三区| 欧美日韩视频一区二区| 成人网在线免费视频| 日本欧美韩国一区三区| 亚洲欧美国产77777| 国产日韩欧美一区二区三区乱码| 91行情网站电视在线观看高清版| 韩国一区二区视频| 亚洲一二三区不卡|