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

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

?? mysqlcommon.pas

?? 通過Tmysql來訪問MSQL Server數據庫的應用案例.
?? PAS
?? 第 1 頁 / 共 5 頁
字號:
unit mySQLCommon;

{
  Unit:    TmySQLCommon - Common Data Structures
  Project: TmySQL - http://www.productivity.org/projects/tmysql
  Author:  Justin P. Yunke <yunke@productivity.org>
  Date:    November 1998 - January 2002
  ** Join the TmySQL mailing list at http://www.elists.org **

  Copyrights/Credits:
    Parts Copyright (c) 2001 Justin P. Yunke <yunke@productivity.org>
    Parts Copyright (c) 2001 Ken Kyler
    T.c.X. DataKonsult AB (mySQL software and component bitmap art)
    Bob Silva <bsilva@umesd.k12.or.us> (_libmysql.pas)

  License:
    Open Source.  You must retain copyrights and distribution information
    listed in these files.

  Description:
    This *.pas file contains some internal code structures for the Tmysql
  project, including TmySQLClientThread, TmySQLClientModify, TmySQLClientQuery,
  and TmySQLClientUtility.
}

interface

uses
  Windows, Messages, Classes, StdCtrls, Forms, mysql;

const
  DEFAULT_DLL_LOCATION   = 'libmySQL.DLL';

  DEBUGFILE_COMMON       = 'mysqlcommon.txt';

{For ChainThreadHandler}
  WM_CHAINTASKHANDLER_COMPLETE = WM_USER + 1;
  WM_CHAINTASKHANDLER_ERROR    = WM_USER + 2;

{Last Modification Information}
  TMYSQLCOMMON_VERSION       = '2.1a';
  TMYSQLCOMMON_LAST_MODIFIED = '01.27.2002';
  TMYSQLCOMMON_LAST_AUTHOR   = 'jpy';

  {TmySQLClientModify constants}
  MAX_SQL_LENGTH       = 65536*2;
  MAX_MEMO_LENGTH      = 32768;

  MAX_LENGTH_HOST      = 255;
  MAX_LENGTH_USER      = 16;
  MAX_LENGTH_PASSWD    = 32;
  MAX_LENGTH_DB        = 64;

  MAX_TASK_NAME_LENGTH = 40;

type
  TRefreshOptions = (
    _REFRESH_GRANT,
    _REFRESH_LOG,
    _REFRESH_TABLES,
    _REFRESH_HOSTS,
    _REFRESH_STATUS,
    _REFRESH_THREADS,
    _REFRESH_SLAVE,
    _REFRESH_MASTER
  );
  TSetRefreshOptions = set of TRefreshOptions;

type
  TClientCapabilities = (
    _CLIENT_LONG_PASSWORD,
    _CLIENT_FOUND_ROWS,
    _CLIENT_LONG_FLAG,
    _CLIENT_CONNECT_WITH_DB,
    _CLIENT_NO_SCHEMA,
    _CLIENT_COMPRESS,
    _CLIENT_ODBC,
    _CLIENT_LOCAL_FILES,
    _CLIENT_IGNORE_SPACE,
    _CLIENT_INTERACTIVE,
    _CLIENT_SSL,
    _CLIENT_IGNORE_SIGPIPE,
    _CLIENT_TRANSACTIONS
  );
  TSetClientCapabilities = set of TClientCapabilities;

//----------------------------------------------------------------------------
//----------------------------------------------------------------------------

type
  TModifyType = (
    MODIFY_INSERT, MODIFY_UPDATE, MODIFY_REPLACE_INTO, MODIFY_DELETE,
    MODIFY_CREATE_TABLE, MODIFY_DROP_TABLE
  );
  TQuoteOptions = (
    QUOTE_STRIP_CR,QUOTE_STRIP_LF,
    QUOTE_DONT_INSERT_SINGLEQUOTES,
    QUOTE_DONT_USE_NULL
  );
  TQuoteOptionsSet = set of TQuoteOptions;

type
  TmySQLClientTaskType = (
    task_mysql_connect,
    task_mysql_close,
    task_mysql_real_connect,

    task_mysql_select_db,
    task_mysql_create_db,
    task_mysql_drop_db,

    task_mysql_query,
    task_mysql_store_result,

    task_mysql_list_db,
    task_mysql_list_tables,
    task_mysql_list_fields,
    task_mysql_list_processes,

    task_mysql_ping,
    task_mysql_shutdown,
    task_mysql_kill,
    task_mysql_options,
    task_mysql_refresh
  );

  TmySQLClientQuery_ExecuteType = (Execute_Stored,Execute_Dynamic);

  TmySQLClientThread_OnComplete = procedure(Sender : TObject; Data : TObject) of object;
  TmySQLClientThread_OnError = procedure(Sender : TObject; Data : TObject; Msg : string) of object;

  TmySQLClientTask_OnComplete = procedure(Sender : TObject) of object;
  TmySQLClientTask_OnError = procedure(Sender : TObject; Msg : string) of object;

  TmySQLClientTask_Status = array[0..4] of string;
  TmySQLClientTask_StatusType = (
    mySQL_Status_NotConnected,
    mySQL_Status_Connecting,
    mySQL_Status_Idle,
    mySQL_Status_Active,
    mySQL_Status_Reconnecting
  );
const
  mySQLClientTask_Status:TmySQLClientTask_Status = ('Not Connected','Connecting','Idle','Active','Reconnecting');

type
  TmySQLClientTask_OnStatus = procedure(Sender : TObject; Status : TmySQLClientTask_StatusType; TaskName : string; TasksLeft : integer) of object;

  TmySQLClientTaskData = class(TObject)
  public
    FName              : string[MAX_TASK_NAME_LENGTH];

    FTaskType          : TmySQLClientTaskType;
    FPrepared          : boolean;

    F_Wild             : pchar;
    F_ListData         : TStringList;
    F_IntegerData      : integer;

    F_table            : pchar;
    F_modifytype       : TModifyType;
    F_condition        : pchar;

    F_query            : pchar;
    F_host, F_user,
    F_passwd, F_db     : pchar;
    F_port             : Cardinal;
    F_unix_socket      : PChar;
    F_clientflag       : Cardinal;

    F_Session          : pmysql;
    F_presults         : pmysql_res;
    F_ret_code         : integer;
    F_pid              : integer;
    F_options          : mysql_option;
    F_refresh_options  : cardinal;
    F_arg              : pchar;

    F_keyfield         : longword;
    F_executetype      : TmySQLClientQuery_ExecuteType;

    FThreadOnComplete  : TmySQLClientThread_OnComplete;
    FThreadOnError     : TmySQLClientThread_OnError;

    FTaskOnComplete    : TmySQLClientTask_OnComplete;
    FTaskOnError       : TmySQLClientTask_OnError;

    constructor Create;
    destructor  Destroy; override;
  end;

  TmySQLClientThread = class(TThread)
  private
    FHandlerWndHandle : HWND;

    FSession : pmysql;

    FTaskList : TList;

    FThreaded : boolean;

    FOnStatus : TmySQLClientTask_OnStatus;
    FOnFinished : TmySQLClientTask_OnComplete;

    procedure   Run(T : TmySQLClientTaskData);
    procedure   Finish(T : TmySQLClientTaskData);

    procedure   PostComplete(T : TmySQLClientTaskData);
    procedure   PostError(T : TmySQLClientTaskData);

    procedure   ResumeNonThread;

    function    GetTaskCount : integer;
  public
    constructor Create(CreateSuspended : boolean);
    destructor  Destroy; override;

    property    Session : pmysql read FSession write FSession;

    property    TaskCount : integer read GetTaskCount;

    property    OnStatus : TmySQLClientTask_OnStatus read FOnStatus write FOnStatus;
    property    OnFinished : TmySQLClientTask_OnComplete read FOnFinished write FOnFinished;

    procedure   Prepare_mysql_real_connect(
      const host, user, passwd, db: pchar;
      port: Cardinal; unix_socket: PChar; clientflag: Cardinal;

      const TaskName : string;

      OnComplete     : TmySQLClientThread_OnComplete;
      OnError        : TmySQLClientThread_OnError;

      OnTaskComplete : TmySQLClientTask_OnComplete;
      OnTaskError    : TmySQLClientTask_OnError
    );

    procedure   Prepare_mysql_close(
      const TaskName : string;

      OnComplete     : TmySQLClientThread_OnComplete;
      OnError        : TmySQLClientThread_OnError;

      OnTaskComplete : TmySQLClientTask_OnComplete;
      OnTaskError    : TmySQLClientTask_OnError
    );

    procedure   Prepare_mysql_db(
      tasktype : TmySQLClientTaskType;

      db : pchar;
      const TaskName : string;

      OnComplete     : TmySQLClientThread_OnComplete;
      OnError        : TmySQLClientThread_OnError;

      OnTaskComplete : TmySQLClientTask_OnComplete;
      OnTaskError    : TmySQLClientTask_OnError
    );

    procedure   Prepare_mysql_query(
      tasktype : TmySQLClientTaskType;

      _query : pchar;

      const TaskName : string;

      OnComplete     : TmySQLClientThread_OnComplete;
      OnError        : TmySQLClientThread_OnError;

      OnTaskComplete : TmySQLClientTask_OnComplete;
      OnTaskError    : TmySQLClientTask_OnError
    );

    procedure   Prepare_mysql_list(
      const TaskType : TmySQLClientTaskType;

      Wild : pchar;

      const TaskName : string;

      OnComplete     : TmySQLClientThread_OnComplete;
      OnError        : TmySQLClientThread_OnError;

      OnTaskComplete : TmySQLClientTask_OnComplete;
      OnTaskError    : TmySQLClientTask_OnError
    );

    procedure   Prepare_mysql_list_fields(
      TableName : pchar;
      Wild : pchar;

      const TaskName : string;

      OnComplete     : TmySQLClientThread_OnComplete;
      OnError        : TmySQLClientThread_OnError;

      OnTaskComplete : TmySQLClientTask_OnComplete;
      OnTaskError    : TmySQLClientTask_OnError
    );

    procedure   Prepare_mysql_list_processes(
      const TaskName : string;

      OnComplete     : TmySQLClientThread_OnComplete;
      OnError        : TmySQLClientThread_OnError;

      OnTaskComplete : TmySQLClientTask_OnComplete;
      OnTaskError    : TmySQLClientTask_OnError
    );

    procedure   Prepare_mysql_ping_shutdown(
      const TaskType : TmySQLClientTaskType;
      const TaskName : string;

      OnComplete     : TmySQLClientThread_OnComplete;
      OnError        : TmySQLClientThread_OnError;

      OnTaskComplete : TmySQLClientTask_OnComplete;
      OnTaskError    : TmySQLClientTask_OnError
    );

    procedure   Prepare_mysql_kill(
      const pid : integer;
      const TaskName : string;

      OnComplete     : TmySQLClientThread_OnComplete;
      OnError        : TmySQLClientThread_OnError;

      OnTaskComplete : TmySQLClientTask_OnComplete;
      OnTaskError    : TmySQLClientTask_OnError
    );

    procedure   Prepare_mysql_options(
      const opt: mysql_option; arg: pchar;
      const TaskName : string;

      OnComplete     : TmySQLClientThread_OnComplete;
      OnError        : TmySQLClientThread_OnError;

      OnTaskComplete : TmySQLClientTask_OnComplete;
      OnTaskError    : TmySQLClientTask_OnError
    );

    procedure   Prepare_mysql_refresh(
      const RefreshOptions: cardinal;
      const TaskName : string;

      OnComplete     : TmySQLClientThread_OnComplete;
      OnError        : TmySQLClientThread_OnError;

      OnTaskComplete : TmySQLClientTask_OnComplete;
      OnTaskError    : TmySQLClientTask_OnError
    );

    procedure   Execute; override;
  end;

  TmySQLClientTaskHandler = class(TObject)
  private
    FWndHandle         : HWND;

    FThreaded          : boolean;
    FThread            : TmySQLClientThread;

    function    GetSession : pmysql;
    procedure   SetSession(Session : pmysql);

    function    GetThreaded : boolean;
    procedure   SetThreaded(B : boolean);
  protected
    procedure   WndProc(var Mesg : TMessage); virtual;
  public
    constructor Create(const BThreaded : boolean); virtual;
    destructor  Destroy; override;

    property    Session : pmysql read GetSession write SetSession;

    property    Threaded : boolean read GetThreaded write SetThreaded;
    property    Thread : TmySQLClientThread read FThread write FThread;

    procedure   StartTasks;

    procedure   DumpTasks;
  end;

type
  TmySQLClientModifyData = class(TObject)
  private
    pData : pchar;
  public
    property Data : pchar read pData write pData;
    destructor Destroy; override;
  end;

  TmySQLClientModify = class(TObject)
  private
    FTaskHandler        : TmySQLClientTaskHandler;

    FData               : TStringList;

    FCurrentTaskData    : TmySQLClientTaskData;

    FDefault_OnComplete : TmySQLClientTask_OnComplete;
    FDefault_OnError    : TmySQLClientTask_OnError;

    procedure   Combine(T : TmySQLClientTaskData);

    procedure   _OnComplete(Sender: TObject; Data: TObject);
    procedure   _OnError(Sender: TObject; Data: TObject; Msg: string);
  protected
  public
    constructor Create;
    destructor  Destroy; override;

    property    TaskHandler : TmySQLClientTaskHandler read FTaskHandler write FTaskHandler;

    property    CurrentTaskData : TmySQLClientTaskData read FCurrentTaskData write FCurrentTaskData;

    property    Default_OnComplete : TmySQLClientTask_OnComplete read FDefault_OnComplete write FDefault_OnComplete;
    property    Default_OnError    : TmySQLClientTask_OnError    read FDefault_OnError    write FDefault_OnError;

    procedure   Add(const Column : string; Data : pchar);
    procedure   AddString(const Column : string; const Data : string);
    procedure   AddInteger(const Column : string; const Data : integer);
    procedure   AddMemo(const Column : string; Memo : TMemo);

    procedure   PrepareCreateTable(Table : pchar; const TaskName : string);
    procedure   PrepareCreateTableTask(
      Table : pchar;
      const TaskName : string;
      OnComplete : TmySQLClientTask_OnComplete;
      OnError    : TmySQLClientTask_OnError
    );

    procedure   PrepareDropTable(Table : pchar; const TaskName : string);
    procedure   PrepareDropTableTask(
      Table : pchar;
      const TaskName : string;
      OnComplete : TmySQLClientTask_OnComplete;
      OnError    : TmySQLClientTask_OnError
    );

    procedure   PrepareInsert(Table : pchar; const TaskName : string);
    procedure   PrepareInsertTask(
      Table : pchar;
      const TaskName : string;
      OnComplete : TmySQLClientTask_OnComplete;
      OnError    : TmySQLClientTask_OnError
    );

    procedure   PrepareUpdate(Table : pchar; Condition : pchar; const TaskName : string);
    procedure   PrepareUpdateTask(
      Table, Condition : pchar;
      const TaskName : string;
      OnComplete : TmySQLClientTask_OnComplete;
      OnError    : TmySQLClientTask_OnError
    );

    procedure   PrepareUpdateString(Table : pchar; const Condition : string; const TaskName : string);
    procedure   PrepareUpdateStringTask(
      Table : pchar; const Condition : string;
      const TaskName : string;
      OnComplete : TmySQLClientTask_OnComplete;
      OnError    : TmySQLClientTask_OnError
    );

    procedure   PrepareReplaceInto(Table : pchar; Condition : pchar; const TaskName : string);
    procedure   PrepareReplaceIntoTask(
      Table, Condition : pchar;
      const TaskName : string;
      OnComplete : TmySQLClientTask_OnComplete;
      OnError    : TmySQLClientTask_OnError
    );

    procedure   PrepareReplaceIntoString(Table : pchar; const Condition : string; const TaskName : string);
    procedure   PrepareReplaceIntoStringTask(
      Table : pchar; const Condition : string;
      const TaskName : string;
      OnComplete : TmySQLClientTask_OnComplete;
      OnError    : TmySQLClientTask_OnError
    );

    procedure   PrepareDelete(Table, Condition : pchar; const TaskName : string);
    procedure   PrepareDeleteTask(
      Table, Condition : pchar;
      const TaskName : string;
      OnComplete : TmySQLClientTask_OnComplete;
      OnError    : TmySQLClientTask_OnError
    );

    procedure   PrepareDeleteString(Table : pchar; const Condition : string; const TaskName : string);
    procedure   PrepareDeleteStringTask(
      Table : pchar; const Condition : string;
      const TaskName : string;
      OnComplete : TmySQLClientTask_OnComplete;
      OnError    : TmySQLClientTask_OnError
    );

    procedure   Reset;
  end;

type
  TmySQLClientQuery = class(TObject)
  private
    FTaskHandler : TmySQLClientTaskHandler;

    FData         : TStringList;
    FFields       : TStringList;
    FFieldsLoaded : boolean;

    FCurrentTaskData : TmySQLClientTaskData;

    FDefault_OnComplete : TmySQLClientTask_OnComplete;
    FDefault_OnError    : TmySQLClientTask_OnError;

    procedure   GetFields;
    function    GetFieldCount : integer;
    function    GetField(const i : longint) : pmysql_field;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日精品一区视频| 久久网这里都是精品| 日韩三级中文字幕| 国产人久久人人人人爽| 三级影片在线观看欧美日韩一区二区| 国产一区二区在线影院| 欧美三级中文字| |精品福利一区二区三区| 久久精品国产色蜜蜜麻豆| 欧美三日本三级三级在线播放| 国产欧美日本一区视频| 麻豆精品国产传媒mv男同| 色哟哟一区二区| 国产精品女人毛片| 国产精品99久久久久久久vr | 日韩一区二区三区在线视频| 一区二区三区免费观看| 91丝袜美腿高跟国产极品老师| 欧美tk—视频vk| 日韩精品久久理论片| 欧美性猛片aaaaaaa做受| 欧美精彩视频一区二区三区| 97se亚洲国产综合自在线不卡| 欧美成人aa大片| 免费不卡在线视频| 51精品秘密在线观看| 午夜精品福利视频网站| 欧洲一区二区三区免费视频| 亚洲欧洲综合另类在线| 99riav一区二区三区| 最新国产精品久久精品| 成人黄色av电影| 自拍偷拍亚洲综合| 91视频在线观看| 亚洲色欲色欲www| 色88888久久久久久影院野外| 亚洲人快播电影网| 色婷婷精品大在线视频| 一个色综合av| 欧美日本一区二区在线观看| 日本视频一区二区| 精品国一区二区三区| 国内偷窥港台综合视频在线播放| 精品成人私密视频| 国产福利一区二区三区视频在线 | 高清beeg欧美| 中文字幕成人av| 91性感美女视频| 亚洲va国产天堂va久久en| 日韩三级伦理片妻子的秘密按摩| 韩国女主播一区二区三区| 久久九九99视频| 成人免费高清在线| 亚洲一级二级三级| 日韩午夜精品视频| 国产福利91精品| 亚洲六月丁香色婷婷综合久久| 欧美日韩亚洲高清一区二区| 麻豆精品一区二区综合av| 亚洲精品在线观看网站| 成人黄色软件下载| 亚洲aⅴ怡春院| 久久午夜色播影院免费高清 | 国产精品白丝在线| 欧美日韩亚洲另类| 风流少妇一区二区| 亚洲第一狼人社区| 久久看人人爽人人| 在线观看精品一区| 国产在线播放一区二区三区| 亚洲婷婷国产精品电影人久久| 欧美一区二区在线视频| 成人av电影免费在线播放| 亚洲成人自拍一区| 国产欧美日韩一区二区三区在线观看| 一本大道综合伊人精品热热| 黄页网站大全一区二区| 亚洲欧美另类小说| 精品国产麻豆免费人成网站| 在线免费精品视频| 韩国精品免费视频| 天天综合网 天天综合色| 亚洲国产精品二十页| 欧美zozo另类异族| 欧美日韩国产精品成人| 99精品视频免费在线观看| 激情图片小说一区| 午夜国产不卡在线观看视频| 综合在线观看色| 精品国产一区二区三区久久久蜜月| 欧美在线三级电影| 9色porny自拍视频一区二区| 精品一区二区三区香蕉蜜桃 | 欧美日韩久久久| 9久草视频在线视频精品| 国产精品一二三区在线| 奇米色777欧美一区二区| 午夜一区二区三区在线观看| 国产精品天美传媒| 久久亚区不卡日本| 精品88久久久久88久久久| 日韩区在线观看| 91精品久久久久久久91蜜桃| 欧美日韩在线直播| 欧洲在线/亚洲| 欧美午夜精品久久久| 色婷婷精品久久二区二区蜜臂av| av在线不卡电影| 成人动漫av在线| 粉嫩aⅴ一区二区三区四区五区| 国产原创一区二区| 久久99久久久欧美国产| 久久9热精品视频| 韩国成人在线视频| 国产一区二区三区免费看 | 青青草伊人久久| 日韩国产欧美三级| 日日摸夜夜添夜夜添国产精品 | 亚洲精品一二三| 国产精品二三区| 国产精品传媒入口麻豆| 国产精品美女一区二区在线观看| 国产欧美精品在线观看| 日本一区二区综合亚洲| 国产精品狼人久久影院观看方式| 国产精品毛片高清在线完整版 | 午夜私人影院久久久久| 亚洲mv大片欧洲mv大片精品| 亚洲成av人片一区二区| 午夜欧美电影在线观看| 美女视频一区在线观看| 六月丁香综合在线视频| 国产露脸91国语对白| 国产99久久久精品| 91亚洲精品一区二区乱码| 欧美性视频一区二区三区| 欧美一区二区在线不卡| 久久精品人人做人人综合| 最新日韩av在线| 日本成人在线一区| 春色校园综合激情亚洲| 在线精品视频一区二区三四 | 色婷婷av一区二区三区大白胸| 欧洲精品中文字幕| 日韩精品在线一区二区| 国产精品福利电影一区二区三区四区| 亚洲一区在线视频| 韩国精品久久久| 欧洲一区在线电影| 久久这里只有精品视频网| 亚洲猫色日本管| 韩国一区二区视频| 欧洲精品在线观看| 久久久久久久久久久久电影 | 在线成人午夜影院| 国产欧美va欧美不卡在线| 亚洲国产精品久久人人爱| 激情欧美日韩一区二区| 在线观看视频91| 久久久一区二区| 午夜精品免费在线| 成人自拍视频在线观看| 51精品秘密在线观看| 亚洲欧美日韩国产综合在线| 精品一区二区精品| 欧美亚洲国产怡红院影院| 国产婷婷色一区二区三区| 午夜精品视频一区| 91麻豆自制传媒国产之光| 久久蜜桃一区二区| 免费高清视频精品| 欧美影院精品一区| 国产精品久久久久久久久晋中| 免费成人在线网站| 欧美日韩免费电影| 自拍偷在线精品自拍偷无码专区 | 在线观看欧美精品| 国产精品久久久99| 国产精品中文字幕日韩精品| 欧美男人的天堂一二区| 亚洲欧美激情视频在线观看一区二区三区| 日韩av不卡在线观看| 欧美在线你懂的| 亚洲乱码精品一二三四区日韩在线| 丰满少妇在线播放bd日韩电影| 精品久久久久久无| 日本亚洲天堂网| 欧美喷潮久久久xxxxx| 亚洲影院免费观看| 99在线精品免费| 国产精品久久久久久妇女6080| 国产精品亚洲专一区二区三区| 精品国产成人系列| 成人国产精品免费网站| 国产亚洲欧美日韩俺去了| 国产精品一二三四| 中文字幕乱码一区二区免费| 国产高清精品久久久久| 亚洲国产精品国自产拍av| 成人激情图片网|