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

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

?? sqliddb.pas

?? MDB版本的LoginSvr跟SQL版本的傳奇源代碼。希望對大家能有用處
?? PAS
字號:
unit SQLIDDB;

interface

uses
  Windows, SysUtils, Classes, Dialogs, Grobal2, MudUtil, DB, ADODB, ActiveX;

type
  TFileIDDB = class
  private
    ADOConnection     :TADOConnection;
    dbQry             :TADOQuery;

    m_boChanged       :Boolean;
    m_OnChange        :TNotifyEvent;
    m_QuickList       :TQuickList;
    nRecordCount      :Integer;

    FCriticalSection  :TRTLCriticalSection;
  private
    procedure LoadQuickList;
    function GetRecord(nIndex: integer; var DBRecord: TAccountDBRecord): boolean;
    function UpdateRecord(nIndex: integer; DBRecord: TAccountDBRecord; btFlag: Byte): boolean;

  public
    constructor Create(sSQL:String);
    destructor Destroy; override;

    procedure Lock;
    procedure UnLock;

    function Open: boolean;
    procedure Close;
    function Index(sName: string): integer;
    function Get(nIndex: integer; var DBRecord: TAccountDBRecord): integer;
    function FindByName(sName: string; var List: TStringList): integer;
    function GetBy(nIndex: integer; var DBRecord: TAccountDBRecord): boolean;
    function Update(nIndex: integer; var DBRecord: TAccountDBRecord): boolean;
    function Add(var DBRecord: TAccountDBRecord): boolean;
    function Delete(nIndex: integer; var DBRecord: TAccountDBRecord): boolean;
  end;

var
  AccountDB: TFileIDDB;

implementation

uses
  LSShare, HUtil32;

constructor TFileIDDB.Create(sSQL:String);
begin
  inherited Create;
  CoInitialize(nil);

  InitializeCriticalSection(FCriticalSection);

  m_QuickList    := TQuickList.Create;
  m_QuickList.boCaseSensitive := False;
  m_boChanged    := False;
  nRecordCount   := -1;
  g_n472A6C      := 0;
  g_n472A74      := 0;
  g_boDataDBReady := False;

  ADOConnection := TADOConnection.Create(nil);
  dbQry := TADOQuery.Create(nil);

  ADOConnection.ConnectionString := sSQL;
  ADOConnection.LoginPrompt := False;
  ADOConnection.KeepConnection := True;

  dbQry.Connection := ADOConnection;
  dbQry.Prepared := True;

  try
    ADOConnection.Connected := True;
    LoadQuickList;
  except
    MainOutMessage('[警告] Account數據庫連接失敗!請檢查IDDB目錄Account.mdb數據庫是否正確。。。');
  end;
end;






destructor TFileIDDB.Destroy;
begin
  m_QuickList.Free;
  DeleteCriticalSection(FCriticalSection);

  dbQry.Free;
  ADOConnection.Free;

  CoUnInitialize;
  inherited;
end;

function TFileIDDB.Open: boolean;
begin
  Result := False;
  Lock();

  m_boChanged    := False;
  Result := True;
end;

procedure TFileIDDB.Close;
begin
  if m_boChanged and Assigned(m_OnChange) then begin
    m_OnChange(Self);
  end;

  UnLock();
end;






procedure TFileIDDB.LoadQuickList;
var
  nIndex:   integer;
  boDeleted :Boolean;
  sAccount  :String;
resourcestring
  sSQL = 'SELECT * FROM TBL_ACCOUNT';
begin
  nRecordCount := -1;
  g_n472A6C := 0;
  g_n472A70 := 0;
  g_n472A74 := 0;
  m_QuickList.Clear;

  Lock;
  try
    try
      dbQry.SQL.Clear;
      dbQry.SQL.Add(sSQL);
      try
        dbQry.Open;
      except
        MainOutMessage('[Exception] TFileIDDB.LoadQuickList');
      end;

      nRecordCount := dbQry.RecordCount;
      g_n472A74 := nRecordCount;
      for nIndex := 0 to nRecordCount - 1 do begin
        Inc(g_n472A6C);

        boDeleted   := dbQry.FieldByName('FLD_DELETED').AsBoolean;
        sAccount    := Trim(dbQry.FieldByName('FLD_LOGINID').AsString);

        if (not boDeleted) and (sAccount <> '') then begin
          m_QuickList.AddObject(sAccount, TObject(nIndex));
          Inc(g_n472A70);
        end;

        dbQry.Next;
      end;
    finally
      dbQry.Close;
    end;
  finally
    UnLock;
  end;

  m_QuickList.SortString(0, m_QuickList.Count - 1);
  g_boDataDBReady := True;
end;


procedure TFileIDDB.Lock;
begin
  EnterCriticalSection(FCriticalSection);
end;

procedure TFileIDDB.UnLock;
begin
  LeaveCriticalSection(FCriticalSection);
end;

function TFileIDDB.FindByName(sName: string; var List: TStringList): integer;
var
  I: integer;
begin
  for I := 0 to m_QuickList.Count - 1 do begin
    if CompareLStr(m_QuickList.Strings[I], sName, length(sName)) then begin
      List.AddObject(m_QuickList.Strings[I], m_QuickList.Objects[I]);
    end;
  end;
  Result := List.Count;
end;

function TFileIDDB.GetBy(nIndex: integer; var DBRecord: TAccountDBRecord): boolean;
begin
  if (nIndex >= 0) and (m_QuickList.Count > nIndex) then Result := GetRecord(nIndex, DBRecord)
  else
    Result := False;
end;

function TFileIDDB.GetRecord(nIndex: integer; var DBRecord: TAccountDBRecord): boolean;
var
  sAccount:String;
resourcestring
  sSQL = 'SELECT * FROM TBL_ACCOUNT WHERE FLD_LOGINID=''%s''';
  sSQL2 = 'SELECT * FROM TBL_ACCOUNTADD WHERE FLD_LOGINID=''%s''';
begin
  Result := True;
  sAccount := m_QuickList[nIndex];


  try
    dbQry.SQL.Clear;
    dbQry.SQL.Add(format(sSQL, [sAccount]));
    try
      dbQry.Open;
    except
      Result := False;
      MainOutMessage('[Exception] TFileIDDB.GetRecord (1)');
      Exit;
    end;

    DBRecord.Header.sAccount      := Trim(dbQry.FieldByName('FLD_LOGINID').AsString);
    DBRecord.Header.sChrName      := '';
    DBRecord.Header.boDeleted     := dbQry.FieldByName('FLD_DELETED').AsBoolean;
    DBRecord.Header.CreateDate    := dbQry.FieldByName('FLD_CREATEDATE').AsDateTime;
    DBRecord.Header.UpdateDate    := dbQry.FieldByName('FLD_LASTUPDATE').AsDateTime;

    DBRecord.nErrorCount          := dbQry.FieldByName('FLD_ERRORCOUNT').AsInteger;
    DBRecord.dwActionTick         := dbQry.FieldByName('FLD_ACTIONTICK').AsInteger;

    DBRecord.UserEntry.sAccount   := Trim(dbQry.FieldByName('FLD_LOGINID').AsString);
    DBRecord.UserEntry.sPassword  := Trim(dbQry.FieldByName('FLD_PASSWORD').AsString);
    DBRecord.UserEntry.sUserName  := Trim(dbQry.FieldByName('FLD_USERNAME').AsString);

    dbQry.SQL.Clear;
    dbQry.SQL.Add(format(sSQL2, [sAccount]));
    try
      dbQry.Open;
    except
      Result := False;
      MainOutMessage('[Exception] TFileIDDB.GetRecord (2)');
    end;

    DBRecord.UserEntry.sSSNo      := Trim(dbQry.FieldByName('FLD_SSNO').AsString);
    DBRecord.UserEntry.sPhone     := Trim(dbQry.FieldByName('FLD_PHONE').AsString);
    DBRecord.UserEntry.sQuiz      := Trim(dbQry.FieldByName('FLD_QUIZ1').AsString);
    DBRecord.UserEntry.sAnswer    := Trim(dbQry.FieldByName('FLD_ANSWER1').AsString);
    DBRecord.UserEntry.sEMail     := Trim(dbQry.FieldByName('FLD_EMAIL').AsString);
    //--------------------------------------------------------------------------------
    DBRecord.UserEntryAdd.sQuiz2  := Trim(dbQry.FieldByName('FLD_QUIZ2').AsString);
    DBRecord.UserEntryAdd.sAnswer2 := Trim(dbQry.FieldByName('FLD_ANSWER2').AsString);
    DBRecord.UserEntryAdd.sBirthDay := Trim(dbQry.FieldByName('FLD_BIRTHDAY').AsString);
    DBRecord.UserEntryAdd.sMobilePhone := Trim(dbQry.FieldByName('FLD_MOBILEPHONE').AsString);
    DBRecord.UserEntryAdd.sMemo   := Trim(dbQry.FieldByName('FLD_MEMO1').AsString);
    DBRecord.UserEntryAdd.sMemo2  := Trim(dbQry.FieldByName('FLD_MEMO2').AsString);
  finally
    dbQry.Close;
  end;
end;

function TFileIDDB.Index(sName: string): integer;
begin
  Result := m_QuickList.GetIndex(sName);
end;

function TFileIDDB.Get(nIndex: integer; var DBRecord: TAccountDBRecord): integer;
begin
  Result := -1;
  if nIndex < 0 then exit;
  if m_QuickList.Count <= nIndex then exit;
  if GetRecord(nIndex, DBRecord) then Result := nIndex
end;



function TFileIDDB.UpdateRecord(nIndex: integer; DBRecord: TAccountDBRecord; btFlag: Byte): boolean;
var
  sdt:String;
begin
  Result := True;
  sdt := FormatDateTime('mm"/"dd"/"yyyy hh":"nn":"ss', Now);

  try
    dbQry.SQL.Clear;

    case btFlag of
      1: begin // New
        dbQry.SQL.Add(format('INSERT INTO TBL_ACCOUNT(FLD_LOGINID, FLD_PASSWORD, FLD_USERNAME, FLD_CREATEDATE, FLD_LASTUPDATE, FLD_DELETED) '+
				                     'VALUES( ''%s'', ''%s'', ''%s'', ''%s'', ''%s'', 0 )',
                             [DBRecord.UserEntry.sAccount,
                             DBRecord.UserEntry.sPassword,
                             DBRecord.UserEntry.sUserName,
                             sdt,
                             sdt]));

        try
          dbQry.ExecSQL;
        except
          Result := False;
          MainOutMessage('[Exception] TFileIDDB.UpdateRecord (1)');
          Exit;
        end;

        dbQry.SQL.Clear;
        dbQry.SQL.Add(format('INSERT INTO TBL_ACCOUNTADD(FLD_LOGINID, FLD_SSNO, FLD_BIRTHDAY, '+
									           'FLD_PHONE, FLD_MOBILEPHONE, FLD_EMAIL, FLD_QUIZ1, FLD_ANSWER1, FLD_QUIZ2, FLD_ANSWER2) '+
                             'VALUES( ''%s'', ''%s'', ''%s'', ''%s'', ''%s'', ''%s'', ''%s'', ''%s'', ''%s'', ''%s'' )',
                             [DBRecord.UserEntry.sAccount,
                             DBRecord.UserEntry.sSSNo,
                             DBRecord.UserEntryAdd.sBirthDay,
                             DBRecord.UserEntry.sPhone,
                             DBRecord.UserEntryAdd.sMobilePhone,
                             DBRecord.UserEntry.sEMail,
                             DBRecord.UserEntry.sQuiz,
                             DBRecord.UserEntry.sAnswer,
                             DBRecord.UserEntryAdd.sQuiz2,
                             DBRecord.UserEntryAdd.sAnswer2]));

        try
          dbQry.ExecSQL;
        except
          Result := False;
          MainOutMessage('[Exception] TFileIDDB.UpdateRecord (2)');
        end;
      end;

      2: begin // Delete
        dbQry.SQL.Add(format('UPDATE TBL_ACCOUNT SET FLD_DELETED=1, FLD_CREATEDATE=''%s'' '+
                             'WHERE FLD_LOGINID=''%s''',
                             [sdt,
                             DBRecord.UserEntry.sAccount]));

        try
          dbQry.ExecSQL;
        except
          Result := False;
          MainOutMessage('[Exception] TFileIDDB.UpdateRecord (3)');
        end;
      end;
      else begin //General Update
        dbQry.SQL.Add(format('UPDATE TBL_ACCOUNT SET FLD_PASSWORD=''%s'', FLD_USERNAME=''%s'', '+
                             'FLD_LASTUPDATE=''%s'', FLD_ERRORCOUNT=%d, FLD_ACTIONTICK=%d WHERE FLD_LOGINID=''%s''',
                             [DBRecord.UserEntry.sPassword,
                             DBRecord.UserEntry.sUserName,
                             sdt,
                             DBRecord.nErrorCount,
                             DBRecord.dwActionTick,
                             DBRecord.UserEntry.sAccount]));

        try
          dbQry.ExecSQL;
        except
          Result := False;
          MainOutMessage('[Exception] TFileIDDB.UpdateRecord (4)');
          Exit;
        end;

        dbQry.SQL.Clear;
        dbQry.SQL.Add(format('UPDATE TBL_ACCOUNTADD SET FLD_SSNO=''%s'', FLD_BIRTHDAY=''%s'', FLD_PHONE=''%s'', '+
                             'FLD_MOBILEPHONE=''%s'', FLD_EMAIL=''%s'', FLD_QUIZ1=''%s'', FLD_ANSWER1=''%s'', FLD_QUIZ2=''%s'', '+
                             'FLD_ANSWER2=''%s'', FLD_MEMO1=''%s'', FLD_MEMO2=''%s'' WHERE FLD_LOGINID=''%s''',
                             [DBRecord.UserEntry.sSSNo,
                             DBRecord.UserEntryAdd.sBirthDay,
                             DBRecord.UserEntry.sPhone,
                             DBRecord.UserEntryAdd.sMobilePhone,
                             DBRecord.UserEntry.sEMail,
                             DBRecord.UserEntry.sQuiz,
                             DBRecord.UserEntry.sAnswer,
                             DBRecord.UserEntryAdd.sQuiz2,
                             DBRecord.UserEntryAdd.sAnswer2,
                             DBRecord.UserEntryAdd.sMemo,
                             DBRecord.UserEntryAdd.sMemo2,
                             DBRecord.UserEntry.sAccount]));

        try
          dbQry.ExecSQL;
        except
          Result := False;
          MainOutMessage('[Exception] TFileIDDB.UpdateRecord (5)');
        end;
      end;
    end;

    m_boChanged := True;
  finally
    dbQry.Close;
  end;
end;

function TFileIDDB.Update(nIndex: integer; var DBRecord: TAccountDBRecord): boolean;
begin
  Result := False;
  if nIndex < 0 then exit;
  if m_QuickList.Count <= nIndex then exit;
  if UpdateRecord(nIndex, DBRecord, 0) then
    Result := True;
end;


function TFileIDDB.Add(var DBRecord: TAccountDBRecord): boolean;
var
  sAccount: string;
  nIndex: integer;
begin
  sAccount := DBRecord.UserEntry.sAccount;
  if m_QuickList.GetIndex(sAccount) >= 0 then begin
    Result := False;
  end else begin
    nIndex := nRecordCount;
    Inc(nRecordCount);

    if UpdateRecord(nIndex, DBRecord, 1) then begin
      m_QuickList.AddRecord(sAccount, nIndex);
      Result := True;
    end else begin
      Result   := False;
    end;
  end;
end;


function TFileIDDB.Delete(nIndex: integer; var DBRecord: TAccountDBRecord): boolean;
begin
  Result := False;
  if nIndex < 0 then exit;
  if m_QuickList.Count <= nIndex then exit;
  if UpdateRecord(nIndex, DBRecord, 2) then begin
    m_QuickList.Delete(nIndex);
    Result := True;
  end;
end;

end.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人av一区二区三区| www.爱久久.com| 久久精品99国产国产精| 捆绑调教美女网站视频一区| 国产麻豆欧美日韩一区| 成人丝袜视频网| 欧美偷拍一区二区| 精品国产乱子伦一区| 国产精品麻豆视频| 亚洲国产欧美在线| 国模冰冰炮一区二区| 色综合色综合色综合| 日韩精品一区二区三区四区视频| 国产偷国产偷亚洲高清人白洁| 亚洲精品视频免费看| 麻豆精品视频在线观看| 成年人午夜久久久| 精品国产乱码91久久久久久网站| 亚洲国产高清aⅴ视频| 三级在线观看一区二区| 97久久精品人人爽人人爽蜜臀| 日韩欧美第一区| 天堂资源在线中文精品| 91免费观看在线| 久久精品视频在线看| 免费亚洲电影在线| 欧美日韩国产片| 亚洲第一福利视频在线| 色哟哟亚洲精品| 亚洲人成小说网站色在线| 国产激情偷乱视频一区二区三区| 日韩欧美在线网站| 日韩成人免费看| 欧美区在线观看| 亚洲午夜在线视频| 欧美日韩一区在线观看| 亚洲欧美二区三区| 91丨porny丨国产入口| 综合av第一页| 色av成人天堂桃色av| 亚洲黄色av一区| 在线看国产一区二区| 一区二区三区在线影院| 欧美在线观看视频一区二区| 亚洲丝袜美腿综合| 在线观看一区日韩| 午夜精品福利久久久| 6080yy午夜一二三区久久| 日韩国产在线观看| 久久久亚洲高清| 成人激情午夜影院| 一区二区高清在线| 日韩一卡二卡三卡四卡| www.综合网.com| 美女任你摸久久| 国产精品国产三级国产普通话蜜臀| 色国产综合视频| 国内精品视频一区二区三区八戒| 国产色综合一区| 欧美一区三区二区| 在线视频欧美精品| 成人免费av网站| 极品少妇一区二区| 五月婷婷综合网| 亚洲乱码国产乱码精品精98午夜| 精品久久久久久综合日本欧美| 在线观看视频一区二区| 成人网在线免费视频| 国产高清亚洲一区| 精品一区二区三区在线观看国产| 一区二区三区高清在线| 国产精品午夜久久| 中文字幕+乱码+中文字幕一区| 日韩欧美国产一区在线观看| 欧美一区二区三区在线观看视频| 91黄色在线观看| 欧洲激情一区二区| 91丨porny丨首页| 欧美在线观看视频在线| 欧美最新大片在线看| 欧美日韩综合在线| 欧美二区三区的天堂| 欧美一区二区不卡视频| 亚洲精品在线电影| 久久久91精品国产一区二区精品| 久久综合九色综合久久久精品综合| 欧美一区二区网站| 久久奇米777| 亚洲主播在线播放| 免费成人在线视频观看| 国产高清久久久久| 久久99久久99小草精品免视看| 蜜臀av一区二区在线免费观看| 国产乱国产乱300精品| 972aa.com艺术欧美| 91精品综合久久久久久| 国产日韩欧美不卡| 亚洲亚洲精品在线观看| 国产麻豆91精品| 一本大道久久a久久综合| 日韩一级黄色大片| 最新中文字幕一区二区三区| 麻豆精品视频在线观看免费| 91免费版在线| 久久久影视传媒| 亚洲成人在线观看视频| 国产成人av电影| 欧美一级高清大全免费观看| 国产精品成人免费精品自在线观看| 天堂久久久久va久久久久| 成人国产一区二区三区精品| 日韩欧美aaaaaa| 麻豆国产精品一区二区三区| 色久综合一二码| 亚洲情趣在线观看| 不卡一区二区在线| ●精品国产综合乱码久久久久 | 国产精品一区不卡| 欧美一区二区视频在线观看2022| 一区二区三区免费| 欧美中文字幕不卡| 亚洲午夜久久久久久久久电影院 | 亚洲免费观看高清完整版在线观看| 久久精品国产亚洲高清剧情介绍| 91精品国产综合久久精品图片| 夜夜精品视频一区二区| 欧美精品久久99| 久久国产精品无码网站| 26uuu成人网一区二区三区| 亚洲第四色夜色| 欧美三级日韩在线| 精品在线视频一区| 国产精品久久毛片a| 日本福利一区二区| 丰满岳乱妇一区二区三区| 亚洲视频中文字幕| 欧美另类z0zxhd电影| 国产精一品亚洲二区在线视频| 国产欧美一区二区三区沐欲 | 国产午夜精品久久| 97久久超碰国产精品| 午夜不卡av免费| 国产亚洲欧美日韩俺去了| 成人一道本在线| 午夜精品久久一牛影视| 精品久久久久久久久久久久久久久 | 日韩精品免费视频人成| 国产欧美一区视频| 欧美精品成人一区二区三区四区| 黄色精品一二区| 亚洲超碰精品一区二区| 国产精品美女久久久久高潮| 9191成人精品久久| 日本韩国欧美三级| 大桥未久av一区二区三区中文| 蜜臀av性久久久久蜜臀aⅴ| 成人免费视频在线观看| 精品国产凹凸成av人网站| 欧美图片一区二区三区| 97久久人人超碰| 高清不卡在线观看av| 美女视频网站久久| 日本在线不卡一区| 日韩精品福利网| 日韩高清在线不卡| 图片区日韩欧美亚洲| 精品国产一区二区三区四区四 | 亚洲一级电影视频| 亚洲国产精品久久久男人的天堂| 成人免费一区二区三区视频| 中文字幕免费在线观看视频一区| 欧美一区二区免费| 日韩一区二区麻豆国产| 7878成人国产在线观看| 日韩视频一区二区在线观看| 日韩午夜中文字幕| 国产日韩欧美综合一区| 国产精品久久久久久久久久免费看| 久久久久久夜精品精品免费| 中文字幕免费不卡在线| 1024成人网色www| 日韩成人一区二区三区在线观看| 老司机免费视频一区二区三区| 国模一区二区三区白浆 | 久久久国产一区二区三区四区小说| 2024国产精品| 亚洲欧美色图小说| 日av在线不卡| 色哟哟在线观看一区二区三区| 欧美综合亚洲图片综合区| 日韩一级免费一区| 国产精品夫妻自拍| 日本亚洲三级在线| 高清国产一区二区| 日韩小视频在线观看专区| 国产精品美女视频| 久久疯狂做爰流白浆xx| 91福利视频在线| 亚洲视频每日更新| 国产一二三精品|