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

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

?? untfunctions.pas

?? 通訊過程中需要某些重要的命令不丟失
?? PAS
?? 第 1 頁 / 共 4 頁
字號:

procedure DeBug(ICon: Variant);
var
  LStr: string;
begin
  if ShowDeBug then begin
    LStr := ICon;
    OutputDebugString(PChar(LStr));
  end;
end;

procedure DeBug(ICon: string; const Args: array of const);
begin
  if ShowDeBug then
    OutputDebugString(PChar(Format(ICon, Args)));
end;

{-------------------------------------------------------------------------------
  過程名:    IsNullBackStr
  作者:      馬敏釗
  日期:      2006.01.06
  參數:      Ivar: Variant
  返回值:    string
  說明:
-------------------------------------------------------------------------------}
{$ENDIF}

{$IFDEF List}
{-------------------------------------------------------------------------------
  過程名:    GetObj
  作者:      馬敏釗
  日期:      2006.01.06
  參數:      Ilist: TStrings; Iidx: Integer
  返回值:    TObject
  說明:
-------------------------------------------------------------------------------}

function GetObj(Ilist: TStrings; Iidx: Integer): TObject;
begin
  Result := Ilist.Objects[Iidx];
end;

{-------------------------------------------------------------------------------
  過程名:    AddList
  作者:      馬敏釗
  日期:      2006.01.06
  參數:      Ilist: Tstrings; ICapTion: string; Iobj: Tobject
  返回值:    無
  說明:
-------------------------------------------------------------------------------}

procedure AddList(Ilist: Tstrings; ICapTion: string; Iobj: Tobject);
begin
  Ilist.AddObject(ICapTion, Iobj);
end;

{-------------------------------------------------------------------------------
  過程名:    ClearList
  作者:      馬敏釗
  日期:      2006.01.06
  參數:      IList: TStrings
  返回值:    無
  說明:
-------------------------------------------------------------------------------}

procedure ClearList(IList: TStrings);
var
  i: Integer;
begin
  for I := 0 to IList.Count - 1 do
    IList.Objects[i].free;
  IList.Clear;
end;

{-------------------------------------------------------------------------------
  過程名:    GetOnlyFileName
  作者:      馬敏釗
  日期:      2006.01.06
  參數:      IfileName:String
  返回值:    string
  說明:      獲取文件名稱 不帶路徑和后綴
-------------------------------------------------------------------------------}

function GetOnlyFileName(IfileName: string): string;
var
  Tmp, Ext: string;
begin
  Tmp := ExtractFileName(IfileName);
  Ext := ExtractFileExt(IfileName);
  Result := copy(Tmp, 1, Length(Tmp) - Length(Ext));
end;

{-------------------------------------------------------------------------------
  過程名:    GetEveryWord
  作者:      馬敏釗
  日期:      2006.01.06
  參數:      S: string; E: TStringList; C: string
  返回值:    無
  說明:      分割字符串 返回的StringList由外部自己管理內存
-------------------------------------------------------------------------------}

procedure GetEveryWord(S: string; E: TStrings; C: string);
var
  t, a: string;
begin
  t := s;
  while Pos(c, t) > 0 do begin
    a := copy(t, 1, pos(c, t) - 1);
    t := copy(t, pos(c, t) + 1, length(t) - pos(c, t));
    e.Add(a);
  end;
  if Trim(t) <> '' then e.Add(t);
end;

{-------------------------------------------------------------------------------
  過程名:    FindFileList
  作者:      馬敏釗
  日期:      2006.01.16
  參數:      path:路徑, filter:文件擴展名過濾, FileList:文件列表, ContainSubDir:是否包含子目錄
  返回值:    無
  說明:     查找一個路徑下的所有文件。
-------------------------------------------------------------------------------}

procedure FindFileList(Path, Filter: string; FileList: TStrings; ContainSubDir: Boolean);
var
  FSearchRec, DSearchRec: TSearchRec;
  FindResult: Cardinal;
begin
  FindResult := FindFirst(path + Filter, sysutils.faAnyFile, FSearchRec);
  try
    while FindResult = 0 do begin
      FileList.Add(FSearchRec.Name);
      FindResult := FindNext(FSearchRec);
    end;
    if ContainSubDir then begin
      FindResult := FindFirst(path + Filter, faDirectory, DSearchRec);
      while FindResult = 0 do begin
        if ((DSearchRec.Attr and faDirectory) = faDirectory)
          and (DSearchRec.Name <> '.') and (DSearchRec.Name <> '..') then
          FindFileList(Path, Filter, FileList, ContainSubDir);
        FindResult := FindNext(DSearchRec);
      end;
    end;
  finally
    FindClose(FindResult);
  end;
end;
{$ENDIF}


{$IFDEF db}

function IsNullReturnStr(Ivar: Variant): string;
begin
  if VarIsNull(Ivar) then
    Result := ''
  else
    Result := Ivar;
end;

{-------------------------------------------------------------------------------
  過程名:    IsNullBackFloat
  作者:      馬敏釗
  日期:      2006.01.06
  參數:      Ivar: Variant
  返回值:    Double
  說明:
-------------------------------------------------------------------------------}

function IsNullReturnFloat(Ivar: Variant): Double;
begin
  if VarIsNull(Ivar) then
    Result := 0
  else
    Result := Ivar;
end;

{-------------------------------------------------------------------------------
  過程名:    IsNullBackint
  作者:      馬敏釗
  日期:      2006.01.06
  參數:      Ivar: Variant
  返回值:    Integer
  說明:
-------------------------------------------------------------------------------}

function IsNullReturnint(Ivar: Variant): Integer;
begin
  if VarIsNull(Ivar) then
    Result := 0
  else
    Result := Ivar;
end;



{ TBaseDbMrg }

constructor TDBMrg.Create(IConStr: string; ICreateBuffCount: Integer = 5);
var
  I: Integer;
begin
  FName := 0;
  FTotCount := 100;
  FAutoFreeConn := True;
  FConn := TADOConnection.Create(nil);
  FConn.LoginPrompt := False;
  FPool := TStringList.Create;
  FConn.ConnectionString := IConStr;
  FConn.Connected := True;
  for I := 0 to ICreateBuffCount do
    GetAnQuery();
  FThread_Check := TCheckThread.Create(False, Self);
end;

constructor TDBMrg.Create(IConn: TADOConnection; ICreateBuffCount: Integer = 5);
var
  I: Integer;
begin
  FName := 0;
  FTotCount := 100;
  FConn := IConn;
  if IConn <> nil then
    FConn.LoginPrompt := False;
  FAutoFreeConn := False;
  FPool := TStringList.Create;
  for I := 0 to ICreateBuffCount - 1 do
    GetAnQuery();
  FThread_Check := TCheckThread.Create(False, Self);
end;

destructor TDBMrg.Destroy;
var
  I: Integer;
begin
  FThread_Check.Terminate;
  if FAutoFreeConn then
    FConn.Free;
  for I := 0 to FPool.Count - 1 do
    FPool.Objects[i].Free;
  FPool.Free;
  inherited;
end;

{-------------------------------------------------------------------------------
  過程名:    TDBMrg.AddAnOutAdo
  作者:      馬敏釗
  日期:      2006.01.11
  參數:      Iado: TADOQuery
  返回值:    無
  說明:      加入一個由外部創建的ADO 幫它管理生命周期和重用
-------------------------------------------------------------------------------}

procedure TDBMrg.AddAnOutAdo(Iado: TADOQuery);
begin
  Iado.Close;
  Iado.Connection := FConn;
  if PoolCount + 1 > FTotCount then raise Exception.Create('已經達到最大限度不允許在添加新的QUERY');
  Iado.Tag := FPool.AddObject(CDb_State_NoneUsed, Iado);
end;

{-------------------------------------------------------------------------------
  過程名:    TDBMrg.BackToPool
  作者:      馬敏釗
  日期:      2006.01.11
  參數:      Iado: TADOQuery
  返回值:    無
  說明:     釋放ADO使用權以便其它人員使用
-------------------------------------------------------------------------------}

procedure TDBMrg.BackToPool(IName: string);
var
  I: Integer;
begin
  for I := 0 to FPool.Count - 1 do begin // Iterate
    if TADOQuery(FPool.Objects[i]).Name = IName then begin
      FPool.Strings[i] := CDb_State_NoneUsed;
    end;
  end; // for
end;

procedure TDBMrg.BackToPool(Iado: TADOQuery);
begin
  if Iado = nil then Exit;
  try
    FPool.Strings[Iado.Tag] := CDb_State_NoneUsed;
  except
    raise Exception.Create('回歸Adoquery的時候異常 Tag屬性被改變');
  end;
end;

{-------------------------------------------------------------------------------
  過程名:    TDBMrg.DeleteSomeThing
  作者:      馬敏釗
  日期:      2006.01.11
  參數:      ItabName, IFieldName: string; Ivalue: Variant
  返回值:    無
  說明:     根據字段名和值刪除表內容
-------------------------------------------------------------------------------}

procedure TDBMrg.DeleteSomeThing(ItabName, IFieldName: string;
  Ivalue: Variant);
begin
  with GetAnQuery(CDb_State_CanUsed) do begin
    try
      Close;
      SQL.Text := Format('Delete from %s where %s=:VarIant', [ItabName, IFieldName]);
      Parameters.ParamValues['VarIant'] := Ivalue;
      ExecSQL;
    finally
      Close;
    end;
  end; // with
end;

{-------------------------------------------------------------------------------
  過程名:    TDBMrg.ExecAnSql
  作者:      馬敏釗
  日期:      2006.01.11
  參數:      Isql: string
  返回值:    Integer
  說明:      執行一個語句
-------------------------------------------------------------------------------}

function TDBMrg.ExecAnSql(Isql: string): Integer;
begin
  with GetAnQuery do begin
    try
      Close;
      SQL.Text := Isql;
      Result := ExecSQL;
    finally // wrap up
      Close;
    end; // try/finally
  end; // with
end;

{-------------------------------------------------------------------------------
  過程名:    TDBMrg.GetAnQuery
  作者:      馬敏釗
  日期:      2006.01.11
  參數:      Iname: string
  返回值:    TADOQuery
  說明:獲取一個ADO對象 可以指定名字 如果沒有名字 系統自己返回一合適的對象
-------------------------------------------------------------------------------}

function TDBMrg.GetAnQuery(Iname: string): TADOQuery;
var
  I: Integer;
begin
  Result := nil;
  if PoolCount > FTotCount then begin
    raise Exception.Create('AdoQuery已經達到最大限制數量!緩沖池不允許再添加新對象' + #13
      + '請檢查是否由于忘記回歸ADOQUERY所導致');
    Exit;
  end;
  if Iname <> '' then begin
    for I := 0 to FPool.Count - 1 do
      if (FPool.Objects[i] as TADOQuery).Name = 'MyPool' + Iname then begin
        Result := FPool.Objects[i] as TADOQuery;
        Exit;
      end;
    Result := TADOQuery.Create(nil);
    Result.Connection := FConn;
    Result.Name := 'MyPool' + Iname;
    Result.Tag := FPool.AddObject(IntToStr(CDb_State_EverUsed), Result);
  end;
end;


function TDBMrg.GetAnQuery(IuserTime: integer = 1; Iname: string = ''):
  TADOQuery;
var
  I: Integer;
  LState: string;
begin
  if IuserTime = CDb_State_CanUsed then
    LState := ''
  else
    LState := IntToStr(IuserTime);
  if PoolCount > FTotCount then begin
    raise Exception.Create('AdoQuery已經達到最大限制數量!緩沖池不允許再添加新對象' + #13
      + '請檢查是否由于忘記回歸ADOQUERY所導致');
    Exit;
  end;
  if Iname <> '' then begin
    for I := 0 to FPool.Count - 1 do
      if (FPool.Objects[i] as TADOQuery).Name = 'MyPool' + Iname then begin
        Result := FPool.Objects[i] as TADOQuery;
        FPool.Strings[i] := LState;
        Exit;
      end;
    Result := TADOQuery.Create(nil);
    Result.Connection := FConn;
    Result.Name := 'MyPool' + Iname;
    Result.Tag := FPool.AddObject(IntToStr(CDb_State_EverUsed), Result);
  end
  else begin
    for I := 0 to FPool.Count - 1 do begin // Iterate
      if (FPool.Strings[i] = CDb_State_NoneUsed) then begin
        Result := FPool.Objects[i] as TADOQuery;
        FPool.Strings[i] := LState;
        Exit;
      end;
    end; // for
    Result := TADOQuery.Create(nil);
    Result.Connection := FConn;
    Inc(FName);
    Result.Name := 'MyPool' + IntToStr(FName);
    Result.Tag := FPool.AddObject(LState, Result);
  end;
end;

{-------------------------------------------------------------------------------
  過程名:    TDBMrg.GetConn
  作者:      馬敏釗
  日期:      2006.01.11
  參數:      無
  返回值:    TADOConnection
  說明:      獲取連接
-------------------------------------------------------------------------------}

function TDBMrg.GetConn: TADOConnection;
begin
  Result := FConn;
end;

{-------------------------------------------------------------------------------
  過程名:    TDBMrg.GetCount
  作者:      馬敏釗
  日期:      2006.01.11
  參數:      ItabName, IFieldName: string; Ivalue: variant
  返回值:    Integer
  說明:      獲取符合記錄的個數
-------------------------------------------------------------------------------}

function TDBMrg.GetCount(ItabName, IFieldName: string; Ivalue: variant):
  Cardinal;
begin
  with GetAnQuery do begin
    Close;
    SQL.Text := Format('Select Count(%s) as MyCount from %s where %s=:variant',
      [IFieldName, ItabName, IFieldName]);
    Parameters.ParamValues['VarIant'] := Ivalue;
    try
      Open;
      Result := Fieldbyname('MyCount').AsInteger;
    except
      Result := 0;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99久久99久久精品免费看蜜桃| 亚洲成人自拍一区| 黑人巨大精品欧美黑白配亚洲| 在线播放中文一区| 日本在线不卡视频一二三区| 欧美伦理影视网| 麻豆精品国产91久久久久久| 欧美大片在线观看一区| 久久不见久久见中文字幕免费| 日韩精品一区二区在线观看| 久久精品国产一区二区三| 欧美精品一区二区三区久久久 | 久久久91精品国产一区二区精品| 极品少妇一区二区三区精品视频| 久久综合九色综合97婷婷女人| 极品美女销魂一区二区三区免费| 精品福利一区二区三区免费视频| 久久99在线观看| 久久综合九色综合97婷婷女人| 久久99九九99精品| 国产视频一区二区在线| 美女视频一区在线观看| 久久综合久久综合久久| 国产成人自拍在线| 亚洲欧洲日韩综合一区二区| 成人国产一区二区三区精品| 亚洲欧美色综合| 欧美性受xxxx黑人xyx| 亚洲高清久久久| 在线视频一区二区三区| 亚洲婷婷在线视频| 一本在线高清不卡dvd| 日本一区二区三区四区 | 国产麻豆视频精品| 久久久久久毛片| av一区二区三区| 亚洲免费在线视频一区 二区| 色婷婷久久久亚洲一区二区三区 | 成人黄动漫网站免费app| 中文字幕中文乱码欧美一区二区| 99久久精品99国产精品 | 国精产品一区一区三区mba桃花| 久久精品一区二区三区四区| 成人激情小说乱人伦| 亚洲国产另类精品专区| 精品久久国产字幕高潮| 成人av手机在线观看| 亚洲二区视频在线| 26uuu欧美| 色综合久久综合网| 麻豆国产精品一区二区三区 | 欧美在线免费观看亚洲| 日韩精品1区2区3区| 欧美日韩综合不卡| 奇米888四色在线精品| 久久色视频免费观看| 国产成人综合网| 亚洲夂夂婷婷色拍ww47| 久久蜜桃av一区精品变态类天堂| 免费精品视频最新在线| 久久久蜜臀国产一区二区| 色婷婷久久久久swag精品| 蜜桃av噜噜一区二区三区小说| 国产精品国产三级国产普通话蜜臀| 在线电影国产精品| av午夜精品一区二区三区| 日韩av中文在线观看| 亚洲婷婷综合久久一本伊一区| 日韩女优av电影| 欧美性videosxxxxx| 成人午夜精品在线| 日本成人在线看| 亚洲在线视频网站| 国产精品高潮久久久久无| 日韩一区二区在线播放| 在线亚洲人成电影网站色www| 国产成人av电影在线观看| 婷婷开心激情综合| 亚洲情趣在线观看| 亚洲国产精品精华液ab| 制服丝袜一区二区三区| 99免费精品在线| 99久久精品国产网站| 手机精品视频在线观看| 亚洲精品一区二区三区蜜桃下载 | 亚洲成人自拍偷拍| 亚洲欧洲一区二区在线播放| 精品久久免费看| 日韩精品自拍偷拍| 5月丁香婷婷综合| 欧美日韩一区高清| 色先锋久久av资源部| 99久久伊人精品| 成人动漫视频在线| 国产91丝袜在线观看| 国产在线国偷精品产拍免费yy| 日韩在线一二三区| 偷拍日韩校园综合在线| 亚洲成av人影院在线观看网| 亚洲国产综合91精品麻豆| 亚洲一区在线视频观看| 亚洲一级不卡视频| 午夜电影一区二区| 日本欧美韩国一区三区| 轻轻草成人在线| 蜜臀va亚洲va欧美va天堂 | 久久久久免费观看| 久久久影院官网| 91精品国产福利| 日韩欧美一区在线| 日韩一卡二卡三卡| 久久久久国产精品麻豆| 国产日韩欧美一区二区三区乱码 | 亚洲精品在线一区二区| 精品蜜桃在线看| 亚洲精品一区二区精华| 日本一二三四高清不卡| 国产亚洲一区二区三区| 中文字幕免费不卡| 一区二区三区日韩欧美| 午夜精品在线看| 精品一区二区影视| 成人黄色777网| 欧美三级一区二区| 日韩三级中文字幕| 国产调教视频一区| 国产精品二三区| 亚洲图片欧美视频| 久久99久国产精品黄毛片色诱| 国产精品一区二区黑丝| 97久久超碰精品国产| 欧美精品aⅴ在线视频| 精品国产精品网麻豆系列| 国产精品免费久久久久| 亚洲综合另类小说| 香蕉成人伊视频在线观看| 国产成人av电影在线| 在线亚洲一区观看| 久久久一区二区三区捆绑**| 成人免费在线播放视频| 亚洲成人免费在线| 国产不卡一区视频| 欧美影视一区二区三区| 日韩一区二区免费电影| 中文字幕欧美激情| 日韩精品成人一区二区在线| 国产99久久久久久免费看农村| 欧洲人成人精品| 精品乱码亚洲一区二区不卡| 成人欧美一区二区三区小说| 日本特黄久久久高潮| 99久久精品一区二区| 制服.丝袜.亚洲.另类.中文 | 久久超级碰视频| 国产大陆a不卡| 91久久免费观看| 欧美日韩国产免费一区二区| 国产精品嫩草99a| 亚洲午夜电影在线观看| 国产乱色国产精品免费视频| 在线观看欧美日本| 国产人妖乱国产精品人妖| 日韩国产精品久久久久久亚洲| 成人精品一区二区三区四区| 91超碰这里只有精品国产| 亚洲视频在线观看三级| 国内成+人亚洲+欧美+综合在线| 色婷婷激情一区二区三区| 国产欧美一区视频| 热久久一区二区| 欧美综合在线视频| 中文字幕色av一区二区三区| 丝袜美腿一区二区三区| 91老司机福利 在线| 国产精品麻豆网站| 韩国一区二区视频| 91精品国产综合久久久蜜臀粉嫩| 中文字幕在线不卡一区| 国产激情偷乱视频一区二区三区| 欧美一区二区三区啪啪| 天天爽夜夜爽夜夜爽精品视频| 95精品视频在线| 欧美高清在线一区| 国产ts人妖一区二区| 精品国产伦理网| 日韩黄色免费电影| 欧美日产国产精品| 亚洲电影视频在线| 欧美日韩一二区| 亚洲黄色免费网站| 欧美日韩精品是欧美日韩精品| 依依成人精品视频| 在线一区二区观看| 亚洲主播在线播放| 欧美卡1卡2卡| 婷婷夜色潮精品综合在线| 91精品国产欧美一区二区18 | 97精品久久久午夜一区二区三区| 国产精品久线在线观看| 99久久伊人精品|