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

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

?? gaadvancedsqlparser.pas

?? 一個sql語法分析程序
?? PAS
?? 第 1 頁 / 共 2 頁
字號:
{*******************************************************}
{                                                       }
{       Advanced SQL statement parser                   }
{       Copyright (c) 2001 AS Gaiasoft                  }
{       Created by Gert Kello                           }
{                                                       }
{*******************************************************}

unit gaAdvancedSQLParser;

interface

uses
  Classes, gaBasicSQLParser, gaLnkList;

type
  TSQLStatementType = (sstSelect, sstInsert, sstUpdate, sstDelete,
    sstCreate, sstAlter, sstDrop, sstUnknown, sstNoStatementFound);

  TSQLStatementTypes = set of TSQLStatementType;

  TgaCustomSQLStatement = class;

  TgaSQLTokenObj = class (TObject)
  private
    FIsOriginal: Boolean;
    FQuoteChar: Char;
    FTokenQuoted: Boolean;
    FTokenString: string;
    FTokenType: TSQLToken;
    function GetTokenAsString: string;
  public
    constructor CreatePlaceHolder;
    procedure AssignTokenInfo(ASQLParser: TgaBasicSQLParser);
    procedure SetTokenInfo(const AString: string; ATokenType: TSQLToken; 
            AQuoted: Boolean; AQuoteChar: char);
    function TokenSymbolIs(const S: string): Boolean;
    property IsOriginal: Boolean read FIsOriginal write FIsOriginal;
    property QuoteChar: Char read FQuoteChar;
    property TokenAsString: string read GetTokenAsString;
    property TokenQuoted: Boolean read FTokenQuoted;
    property TokenString: string read FTokenString;
    property TokenType: TSQLToken read FTokenType;
  end;
  
  TgaTokenEvent = procedure (Sender: TObject; AToken: TgaSQLTokenObj) of object;
  TgaSQLTokenListBookmark = class (TgaDoubleListBookmark)
  private
    function GetTokenObj: TgaSQLTokenObj;
    procedure SetTokenObj(Value: TgaSQLTokenObj);
  public
    property TokenObj: TgaSQLTokenObj read GetTokenObj write SetTokenObj;
  end;
  
  TgaSQLTokenList = class (TgaSharedDoubleList)
  private
    FOwnerStatement: TgaCustomSQLStatement;
  protected
    procedure GetAllTokens(ATokenList: TgaSQLTokenList);
    function GetAsString: string; virtual;
    function GetCurrentItem: TgaSQLTokenObj; reintroduce; virtual;
    function GetTokenObjAsString(ATokenObj: TgaSQLTokenObj): string;
    procedure SetCurrentItem(Value: TgaSQLTokenObj); reintroduce; virtual;
    property OwnerStatement: TgaCustomSQLStatement read FOwnerStatement;
  public
    constructor Create(AOwnerStatement: TgaCustomSQLStatement); virtual;
    constructor CreateMirror(AOwnerStatement: TgaCustomSQLStatement; 
            AMirroredList: TgaSQLTokenList); virtual;
    procedure ExecuteTokenAdded(Sender: TObject; AToken: TgaSQLTokenObj); 
            virtual;
    function GetBookmark: TgaSQLTokenListBookmark; reintroduce; virtual;
    property AsString: string read GetAsString;
    property CurrentItem: TgaSQLTokenObj read GetCurrentItem write 
            SetCurrentItem;
  end;
  
  TgaAdvancedSQLParser = class;

  TgaListOfSQLTokenLists = class (TgaSharedDoubleList)
  private
    FOwnsLists: Boolean;
  protected
    procedure GetAllTokens(ATokenList: TgaSQLTokenList);
    function GetAsString: string; virtual;
    function GetCurrentItem: TgaSQLTokenList; reintroduce; virtual;
    function GetLastItem: TgaSQLTokenList; reintroduce; virtual;
    procedure Notify(Ptr: Pointer; Action: TListNotification); override;
  public
    constructor Create;
    procedure ExecuteTokenAdded(Sender: TObject; AToken: TgaSQLTokenObj); 
            virtual;
    property AsString: string read GetAsString;
    property CurrentItem: TgaSQLTokenList read GetCurrentItem;
    property LastItem: TgaSQLTokenList read GetLastItem;
    property OwnsLists: Boolean read FOwnsLists write FOwnsLists;
  end;
  
  TgaSQLSTatementClass = class of TgaCustomSQLStatement;

  TgaSQLTokenHolderList = class (TgaSQLTokenList)
  private
    FOwnsAll: Boolean;
    FOwnsNonOriginal: Boolean;
  protected
    procedure Notify(Ptr: Pointer; Action: TListNotification); override;
  public
    procedure AddToken(AToken: TgaSQLTokenObj);
    function NewToken: TgaSQLTokenObj; virtual;
    procedure SetOwner(AOwner: TgaCustomSQLStatement);
    property OwnsAll: Boolean read FOwnsAll write FOwnsAll;
    property OwnsNonOriginal: Boolean read FOwnsNonOriginal write 
            FOwnsNonOriginal;
  end;
  
  TgaNoSQLStatement = class;

  TgaCustomSQLStatement = class (TObject)
  private
    FAllFields: TgaListOfSQLTokenLists;
    FAllTables: TgaListOfSQLTokenLists;
    FCurrentSQL: TgaSQLTokenHolderList;
    FCurrentToken: TgaSQLTokenObj;
    FInternalStatementState: Integer;
    FOnTokenAdded: TgaTokenEvent;
    FOriginalSQL: TgaSQLTokenHolderList;
    FOwnerParser: TgaAdvancedSQLParser;
    FOwnerStm: TgaCustomSQLStatement;
    FStatusCode: Integer;
    procedure SetStatusCode(Value: Integer);
  protected
    procedure DoAfterStatementStateChange; virtual;
    procedure DoBeforeStatementStateChange(const NewStateOrd: LongInt); virtual;
    procedure DoStatementComplete; virtual;
    function GetAsString: string; virtual;
    function GetStatementType: TSQLStatementType; virtual; abstract;
    procedure ModifyStatementInErrorState(Sender: TObject; AToken: 
            TgaSQLTokenObj); virtual;
    procedure ModifyStatementInNormalState(Sender: TObject; AToken: 
            TgaSQLTokenObj); virtual;
    property CurrentToken: TgaSQLTokenObj read FCurrentToken write 
            FCurrentToken;
    property InternalStatementState: Integer read FInternalStatementState write 
            FInternalStatementState;
    property OwnerParser: TgaAdvancedSQLParser read FOwnerParser;
    property OwnerStm: TgaCustomSQLStatement read FOwnerStm;
  public
    constructor Create(AOwner: TgaAdvancedSQLParser); virtual;
    constructor CreateFromStatement(AOwner: TgaAdvancedSQLParser; AStatement: 
            TgaNoSQLStatement); virtual;
    constructor CreateOwned(AOwner: TgaAdvancedSQLParser; AOwnerStatement: 
            TgaCustomSQLStatement); virtual;
    destructor Destroy; override;
    procedure AddField(AField: TgaSQLTokenList);
    procedure AddTable(ATable: TgaSQLTokenList);
    procedure Clear; virtual;
    procedure DoTokenAdded(Sender: TObject; AToken: TgaSQLTokenObj); virtual;
    procedure DoTokenParsed;
    procedure ReleaseOwnedItems;
    procedure RemoveField(AField: TgaSQLTokenList);
    procedure RemoveTable(ATable: TgaSQLTokenList);
    property AllFields: TgaListOfSQLTokenLists read FAllFields;
    property AllTables: TgaListOfSQLTokenLists read FAllTables;
    property AsString: string read GetAsString;
    property CurrentSQL: TgaSQLTokenHolderList read FCurrentSQL;
    property OnTokenAdded: TgaTokenEvent read FOnTokenAdded write FOnTokenAdded;
    property OriginalSQL: TgaSQLTokenHolderList read FOriginalSQL;
    property StatementType: TSQLStatementType read GetStatementType;
    property StatusCode: Integer read FStatusCode write SetStatusCode;
  end;
  
  TgaAdvancedSQLParser = class (TgaBasicSQLParser)
  private
    FCurrentStatement: TgaCustomSQLStatement;
    FOnStatementComplete: TNotifyEvent;
    function GetCurrentStatement: TgaCustomSQLStatement;
  protected
    procedure DoStatementComplete; virtual;
    procedure DoTokenParsed; override;
    procedure SetCurrentStatement(AStatement: TgaCustomSQLStatement);
  public
    destructor Destroy; override;
    class function AddStatementClass(const ATokenSymbol: string; 
            AStatementClass: TgaSQLSTatementClass): Integer;
    function GetStatementClass: TgaSQLSTatementClass;
    class function GetStatementClassForToken(const ATokenSymbol: string): 
            TgaSQLSTatementClass;
    class procedure RemoveStatementClass(const ATokenSymbol: string; 
            AStatementClass: TgaSQLSTatementClass);
    procedure Reset; override;
    property CurrentStatement: TgaCustomSQLStatement read GetCurrentStatement;
    property OnStatementComplete: TNotifyEvent read FOnStatementComplete write 
            FOnStatementComplete;
  end;
  
  TgaUnkownSQLStatement = class (TgaCustomSQLStatement)
  protected
    function GetStatementType: TSQLStatementType; override;
  end;
  
  TgaNoSQLStatement = class (TgaCustomSQLStatement)
  protected
    function GetStatementType: TSQLStatementType; override;
    procedure ModifyStatementInNormalState(Sender: TObject; AToken: 
            TgaSQLTokenObj); override;
  end;
  
const
  DMLStatementTypes = [sstSelect, sstInsert, sstUpdate, sstDelete];
  DDLStatementTypes = [sstCreate, sstAlter, sstDrop];

  errWrongKeywordSequence = $101;
  errUnexpectedTokenInStatement = $102;

procedure TrimTokenList(ATokenList: TgaSQLTokenList;
    const FreeRemovedTokens: boolean;
    TrimmedTokenTypes: TSQLTokenTypes = [stDelimitier, stEnd]);

implementation

uses
  SysUtils, gaSelectStm, gaUpdateStm, gaDeleteStm, gaInsertStm,
  gaSQLParserConsts;

var
  StatementClassList: TStrings;

procedure TrimTokenList(ATokenList: TgaSQLTokenList;
    const FreeRemovedTokens: boolean;
    TrimmedTokenTypes: TSQLTokenTypes = [stDelimitier, stEnd]);
begin
  ATokenList.First;
  while (not ATokenList.Eof) and (ATokenList.CurrentItem.TokenType in TrimmedTokenTypes) do
  begin
    if FreeRemovedTokens then
      ATokenList.CurrentItem.Free;
    ATokenList.DeleteCurrent;
  end;
  ATokenList.Last;
  while (not ATokenList.Bof) and (ATokenList.CurrentItem.TokenType in TrimmedTokenTypes) do
  begin
    if FreeRemovedTokens then
      ATokenList.CurrentItem.Free;
    ATokenList.DeleteCurrent;
    ATokenList.Previous;
  end;
end;

{
**************************** TgaSQLTokenHolderList *****************************
}
procedure TgaSQLTokenHolderList.AddToken(AToken: TgaSQLTokenObj);
begin
  Add(AToken);
  Last;
end;

function TgaSQLTokenHolderList.NewToken: TgaSQLTokenObj;
begin
  Result := TgaSQLTokenObj.Create;
  AddToken(Result);
end;

procedure TgaSQLTokenHolderList.Notify(Ptr: Pointer; Action: TListNotification);
begin
  if Action = lnDeleted then
    if OwnsAll then
      TgaSQLTokenObj(Ptr).Free
    else begin
      if OwnsNonOriginal then
        if not TgaSQLTokenObj(Ptr).IsOriginal then
          TgaSQLTokenObj(Ptr).Free;
    end;
  inherited Notify(Ptr, Action);
end;

procedure TgaSQLTokenHolderList.SetOwner(AOwner: TgaCustomSQLStatement);
begin
  FOwnerStatement := AOwner;
end;

{
**************************** TgaCustomSQLStatement *****************************
}
constructor TgaCustomSQLStatement.Create(AOwner: TgaAdvancedSQLParser);
begin
  inherited Create;
  FOwnerParser := AOwner;
  FStatusCode := 0;
  FOnTokenAdded := ModifyStatementInNormalState;
  FAllFields := TgaListOfSQLTokenLists.Create;
  FAllTables := TgaListOfSQLTokenLists.Create;
  FCurrentSQL := TgaSQLTokenHolderList.Create(Self);
  FOriginalSQL := TgaSQLTokenHolderList.Create(Self);
  FOriginalSQL.OwnsAll := True;
  FCurrentSQL.OwnsNonOriginal := True;
  FAllTables.OwnsLists := False;
  FAllFields.OwnsLists := False;
end;

constructor TgaCustomSQLStatement.CreateFromStatement(AOwner: 
        TgaAdvancedSQLParser; AStatement: TgaNoSQLStatement);
begin
  FOwnerParser := AOwner;
  FStatusCode := 0;
  FOnTokenAdded := ModifyStatementInNormalState;
  FCurrentToken := AStatement.CurrentToken;
  FAllFields := AStatement.AllFields;
  FAllTables := AStatement.AllTables;
  FCurrentSQL := AStatement.CurrentSQL;
  FOriginalSQL := AStatement.OriginalSQL;
  AStatement.ReleaseOwnedItems;
  CurrentSQL.SetOwner(Self);
  OriginalSQL.SetOwner(Self);
  inherited Create;
end;

constructor TgaCustomSQLStatement.CreateOwned(AOwner: TgaAdvancedSQLParser; 
        AOwnerStatement: TgaCustomSQLStatement);
begin
  inherited Create;
  FOwnerParser := AOwner;
  FOwnerStm := AOwnerStatement;
  FStatusCode := 0;
  FOnTokenAdded := ModifyStatementInNormalState;
  FAllFields := TgaListOfSQLTokenLists.Create;
  FAllTables := TgaListOfSQLTokenLists.Create;
  FCurrentSQL := TgaSQLTokenHolderList.CreateMirror(Self, AOwnerStatement.CurrentSQL);
  FOriginalSQL := TgaSQLTokenHolderList.CreateMirror(Self, AOwnerStatement.CurrentSQL);
  FOriginalSQL.OwnsAll := False;
  FCurrentSQL.OwnsNonOriginal := False;
  FAllTables.OwnsLists := False;
  FAllFields.OwnsLists := False;
end;

destructor TgaCustomSQLStatement.Destroy;
begin
  Clear;
  FAllFields.Free;
  FAllTables.Free;
  FCurrentSQL.Free;
  FOriginalSQL.Free;
  inherited Destroy;
end;

procedure TgaCustomSQLStatement.AddField(AField: TgaSQLTokenList);
begin
  AllFields.Add(AField);
  if Assigned(OwnerStm) then
    OwnerStm.AddField(AField);
end;

procedure TgaCustomSQLStatement.AddTable(ATable: TgaSQLTokenList);
begin
  FAllTables.Add(ATable);
  if Assigned(OwnerStm) then
    OwnerStm.AddTable(ATable);
end;

procedure TgaCustomSQLStatement.Clear;
begin
  if Assigned(CurrentSQL) then
    CurrentSQL.Clear;
  if Assigned(OriginalSQL) then
    OriginalSQL.Clear;
  if Assigned(AllTables) then
    AllTables.Clear;
  if Assigned(AllFields) then
    AllFields.Clear;
end;

procedure TgaCustomSQLStatement.DoAfterStatementStateChange;
begin
  ;// Do nothing here
end;

procedure TgaCustomSQLStatement.DoBeforeStatementStateChange(const NewStateOrd: 
        LongInt);
begin
  ;// Do nothing here
end;

procedure TgaCustomSQLStatement.DoStatementComplete;
begin
  if Assigned(FOwnerParser) then
    FOwnerParser.DoStatementComplete;
end;

procedure TgaCustomSQLStatement.DoTokenAdded(Sender: TObject; AToken: 
        TgaSQLTokenObj);
begin
  CurrentSQL.Last;
  if Assigned(FOnTokenAdded) then FOnTokenAdded(Sender, AToken);
end;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91在线免费播放| 中文一区一区三区高中清不卡| 日韩视频在线你懂得| 久久精品人人做| 五月婷婷综合在线| 丰满白嫩尤物一区二区| 日本一二三不卡| 日韩影院免费视频| 日本精品视频一区二区| 久久精品一区二区三区四区| 亚洲成人av在线电影| 91麻豆免费看片| 中文一区一区三区高中清不卡| 捆绑变态av一区二区三区| 在线精品观看国产| 自拍偷拍国产亚洲| 丁香另类激情小说| 国产性色一区二区| 老司机免费视频一区二区| 欧美三级资源在线| 亚洲精品成人在线| 99久久国产免费看| 国产精品毛片a∨一区二区三区| 日本久久电影网| 日韩一区二区三免费高清| 亚洲综合免费观看高清在线观看| 国产一区二区三区四| 日韩美女在线视频| 免费在线观看日韩欧美| 欧美视频一区二区三区在线观看 | 精品福利在线导航| 日韩精品午夜视频| 6080午夜不卡| 舔着乳尖日韩一区| 91精品国产色综合久久| 亚洲mv在线观看| 欧美精选午夜久久久乱码6080| 一区二区在线看| 欧美系列在线观看| 亚洲成a人在线观看| 欧美精品1区2区3区| 美女被吸乳得到大胸91| 69久久99精品久久久久婷婷| 琪琪一区二区三区| 精品美女一区二区| 国产精品一区二区91| 国产精品国产三级国产有无不卡 | 蜜臂av日日欢夜夜爽一区| 日韩欧美一级在线播放| 毛片av一区二区三区| 久久精品一区二区三区不卡牛牛 | 国产一区二三区| 中文字幕高清不卡| 在线视频一区二区免费| 日韩在线卡一卡二| 久久亚洲精华国产精华液| 成人在线综合网站| 亚洲免费伊人电影| 欧美一级日韩免费不卡| 国产精品影视天天线| 亚洲欧美激情插| 欧美草草影院在线视频| 粉嫩av一区二区三区在线播放| 日韩理论片在线| 欧美精品色一区二区三区| 国产自产视频一区二区三区| 国产精品的网站| 欧美伦理电影网| 国产精品69毛片高清亚洲| 亚洲欧美激情视频在线观看一区二区三区| 欧美日韩在线观看一区二区 | 国产色产综合色产在线视频| 99视频在线精品| 日韩国产精品久久久| 国产精品美日韩| 91精品一区二区三区在线观看| 国产精品91xxx| 日韩精品一二三区| 最新不卡av在线| 久久亚洲综合av| 精品视频一区二区不卡| 成人手机电影网| 麻豆免费精品视频| 亚洲一区在线观看免费观看电影高清 | 国产精品一区2区| 午夜视黄欧洲亚洲| 中文字幕在线视频一区| 日韩精品一区二区三区视频在线观看 | 中文字幕精品一区二区精品绿巨人| 欧美性受极品xxxx喷水| 风间由美中文字幕在线看视频国产欧美| 性做久久久久久| 亚洲精品国产无套在线观| 久久久亚洲综合| 欧美一级二级三级蜜桃| 欧美影片第一页| 成人av影院在线| 国产成人综合网| 久久国产精品第一页| 天堂精品中文字幕在线| 亚洲乱码国产乱码精品精可以看| 久久精品人人做人人综合| 欧美精品一区二区三区视频| 欧美电影影音先锋| 欧美色综合天天久久综合精品| k8久久久一区二区三区 | 久久久噜噜噜久噜久久综合| 91精品国产入口| 欧美日韩国产在线播放网站| 色悠久久久久综合欧美99| 不卡高清视频专区| 成人午夜av电影| 国产成人精品免费在线| 国产精品一级黄| 国产精华液一区二区三区| 国产伦精品一区二区三区免费迷| 另类小说欧美激情| 久久成人免费日本黄色| 极品美女销魂一区二区三区| 麻豆精品在线看| 韩国av一区二区三区在线观看| 韩国成人在线视频| 国产91色综合久久免费分享| 成人蜜臀av电影| eeuss影院一区二区三区 | 欧美日免费三级在线| 欧美色综合网站| 日韩一区二区麻豆国产| 欧美电视剧免费全集观看| 91精品国产综合久久香蕉麻豆| 777午夜精品视频在线播放| 日韩一级二级三级精品视频| 精品久久久久久久久久久久久久久久久 | fc2成人免费人成在线观看播放| 99热这里都是精品| 在线中文字幕一区二区| 91精品蜜臀在线一区尤物| 日韩精品一区二区在线| 国产日韩欧美一区二区三区乱码| 国产精品色哟哟网站| 亚洲精品久久久久久国产精华液| 天天亚洲美女在线视频| 狠狠狠色丁香婷婷综合激情 | 精品亚洲成a人| 成人精品鲁一区一区二区| 色香蕉久久蜜桃| 亚洲欧美日韩国产一区二区三区| 亚洲动漫第一页| 精品一区二区在线观看| 99国产精品久久久久久久久久久| 欧洲av一区二区嗯嗯嗯啊| 精品国产免费人成电影在线观看四季 | 国产精品久久久久影院| 亚洲国产成人av| 国产福利精品导航| 欧美偷拍一区二区| 国产亚洲美州欧州综合国| 一区二区三区在线观看欧美| 九色porny丨国产精品| 色婷婷激情一区二区三区| 欧美成人免费网站| 一区二区三区色| 国产成人一级电影| 精品视频1区2区| 亚洲欧美综合色| 久久草av在线| 欧美性xxxxxx少妇| 亚洲欧美中日韩| 国产精品一区二区男女羞羞无遮挡 | 成人国产精品免费观看动漫| 欧美疯狂性受xxxxx喷水图片| 国产精品私房写真福利视频| 美女在线一区二区| 欧美视频一区二区在线观看| 国产精品不卡在线| 国产成人综合在线| 日韩欧美第一区| 五月天欧美精品| 色94色欧美sute亚洲13| 国产精品久久久爽爽爽麻豆色哟哟 | 一本一道综合狠狠老| 久久久久久久久99精品| 免费观看一级欧美片| 欧美亚洲禁片免费| 亚洲美女屁股眼交| av电影在线观看完整版一区二区| 欧美精品一区二区三区四区| 免费精品视频在线| 91精品一区二区三区久久久久久| 亚洲无线码一区二区三区| 色综合久久久久久久| 国产精品毛片大码女人| 成人动漫中文字幕| 中文在线一区二区| 国产91富婆露脸刺激对白| 国产日本一区二区| 豆国产96在线|亚洲| 中文字幕成人网| 99v久久综合狠狠综合久久| 国产精品国产三级国产aⅴ中文|