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

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

?? myldbsqlprocessor.pas

?? 一個本地database引擎,支持中文T_Sql查詢,兼容DELPHI標準數據庫控件
?? PAS
?? 第 1 頁 / 共 5 頁
字號:
unit MYLDBSQLProcessor;

{$I MYLDBVer.inc}

interface

uses Classes, SysUtils, Windows, DB,

     {$IFDEF DEBUG_LOG}
     MYLDBDebug,
     {$ENDIF}

{$IFNDEF D6H}
     MYLDBD4Routines,
{$ENDIF}

     MYLDBLexer,
     MYLDBBase,
     MYLDBRelationalAlgebra,
     MYLDBTypes,
     MYLDBExpressions,
     MYLDBVariant,
     MYLDBCompression,
     MYLDBConst,
     MYLDBConverts,
     MYLDBExcept;

 type
  TMYLDBSQLUnion = class;


////////////////////////////////////////////////////////////////////////////////
//
// TMYLDBTableReference
//
////////////////////////////////////////////////////////////////////////////////

  // reference to the "table" in FROM clause
  TMYLDBTableReference = class (TObject)
   public
    TableType:        TMYLDBTableType;      // Table | JoinedTable | SubQuery
    DatabaseName:     string;             // database1
    TableName:        string;             // table1
    Pseudonym:        string;             // table1 as t1
    Password:         string;             // table1 PASSWORD 'password'
    InMemory:         Boolean;            // [MEMORY]
    NaturalJoin:      Boolean;            // Natural join?
    JoinType:         TMYLDBJoinType;       // inner | left | ...
    LeftTable:        TMYLDBTableReference; // left table in join
    RightTable:       TMYLDBTableReference; // right table in join
    UsingFields:      TStringList;        // join column list
    SearchCondition:  TMYLDBExpression;     // ON '(t1.Field1 = t2.Field2)'
    SubQuery:         TMYLDBSQLUnion;       // subquery
    ExternalDBToFree: TObject;

    // creates
    constructor Create;
    // destroys
    destructor Destroy; override;
    // makes join (left and right node-table)
    procedure MakeJoin(RightNode: TMYLDBTableReference; JType: TMYLDBJoinType;
                     IsNatural: Boolean; Fields: TStringList;
                     OnCondition: TMYLDBExpression);
    // makes subquery
    procedure MakeSubQuery(Lexer: TMYLDBLexer; Query: TDataSet);
  end;//TMYLDBTableReference


////////////////////////////////////////////////////////////////////////////////
//
// TMYLDBSQLCommand
// base class for TMYLDBSQLSelect, TMYLDBSQLUpdate, ...
//
////////////////////////////////////////////////////////////////////////////////

   // base class for TMYLDBSQLSelect, TMYLDBSQLUpdate, ...
  TMYLDBSQLCommand = class (TObject)
   protected
    LLex:         TMYLDBLexer;   // lexer with expression to parse
    Token:        TToken;      // current token
    LQuery:       TDataSet;
    RowsAffected: Integer;
    IntoMemory:   Boolean;     // into memory table?
   private
    // parses list of columns (without table name): field1, field2, ...
    procedure ParseColumnList(var Fields: TStringList);
    // parses list of fields:  table.field1, field2, ..
    procedure ParseFieldList(var Fields: TMYLDBFields);

    // get current token
    function GetCurrentToken: Boolean;
    // get next token
    function GetNextToken: Boolean; overload;
    // get token and lokks at next token with check for token type restrictions
    function GetNextToken(PermittedTypes: TTokenTypes;
                          NativeErrorCode: integer;
                          ErrorText: String): Boolean; overload;

   protected
    procedure ParseTableNameToken(var DatabaseFileName, TableName, TableAlias, Password: String; var InMemory: Boolean);
    procedure CreateDbAndTableComponents(
                          Query: TDataSet;
                          DatabaseFileName, TableName, Password: String;
                          InMemory: Boolean;
                          var Table: TDataset;
                          var DB: TObject);
    procedure FreeDbAndTableComponents(Table: TDataset; DB: TObject);

   public
    // creates object
    constructor Create(Lexer: TMYLDBLexer; Query: TDataSet);
    // parses query
    procedure Parse; virtual; abstract;
    // executes query
    procedure ExecSQL(
                      query: TDataset;
                      IsRoot,
                      RequestLive: boolean;
                      var ReadOnly: boolean;
                      ParentQueryAO: TMYLDBAO = nil;
                      ParentCursor: TMYLDBCursor = nil
                     ); virtual; abstract;
    // get result cursor
    function GetResultCursor: TMYLDBCursor; virtual;
    // gets result dataset
    function GetResultDataset: TDataset; virtual;
    // check pseudonym
    function CheckPseudonym(var Pseudonym: String): Boolean;
  end;//TMYLDBSQLCommand



////////////////////////////////////////////////////////////////////////////////
//
// TMYLDBSQLCursorCommand
// base class for SQL command with cursor
//
////////////////////////////////////////////////////////////////////////////////


 TMYLDBSQLCursorCommand = class (TMYLDBSQLCommand)
  protected
   ResultDataset:         TDataset;  // query component
   IntoDatabase:          string;    // select into <database>.<table>
   IntoTable:             string;    // select into <database>.<table>
   IntoImmediate:         Boolean;   // select into direct memory table?
   OrderBySpecs:          array of TMYLDBSortSpecification;
   OrderBySpecsCount:     integer;

   function OpenAndLockTablesBeforeSelect: Boolean;
   function UnlockTablesAfterSelect: Boolean;

   // <sort key> [ <collate clause> ] [ <ordering specification> ]
   function ParseSortSpecification: Boolean;
   // ORDER BY
   function ParseOrderByClause: Boolean;
   // applies Order By clause
   procedure ApplyOrderBy(AO: TMYLDBAO);

  public
   RootAO:                TMYLDBAO;   // top level AO

   // creates object
   constructor Create(Lexer: TMYLDBLexer; Query: TDataSet);
   // destroys object
   destructor Destroy; override;
   // executes query
   //procedure ExecSQL(query: TDataset; IsRoot: Boolean = False); override;
   procedure ExecSQL(
                      query: TDataset;
                      IsRoot,
                      RequestLive: boolean;
                      var ReadOnly: boolean;
                      ParentQueryAO: TMYLDBAO = nil;
                      ParentCursor: TMYLDBCursor = nil
                    ); override;
   // check if correlated subquery apllied
   function AllConditionsApplied: Boolean; virtual; abstract;
   // builds AO tree
   function BuildAOTree(query: TDataset; RequestLive: Boolean; ParentQueryAO: TMYLDBAO;
    ParentCursor: TMYLDBCursor; AllowNotAppliedConditions: Boolean): TMYLDBAO; virtual; abstract;

   // get result cursor
   function GetResultCursor: TMYLDBCursor; override;
   // get result dataset
   function GetResultDataset: TDataset; override;
 end;//TMYLDBSQLCursorCommand



////////////////////////////////////////////////////////////////////////////////
//
// TMYLDBSQLProcessor
//
////////////////////////////////////////////////////////////////////////////////


  TMYLDBSQLProcessor = class (TObject)
   private
    MYLDBQuery:       TDataSet;
    FReadOnly:      Boolean;
    FRequestLive:   Boolean;
    FInMemory:      Boolean;
    FRowsAffected:  TMYLDBRecordNo;
    FLex:           TMYLDBLexer;

    FSqlText:       String;
    FSQLParams:     TMYLDBSQLParams;
    FCursor:        TMYLDBCursor;

    Queries:        array of TMYLDBSQLCommand; // objects fullfilled by parser
   private

    // parse SQL script and fullfill SQL command objects
    function ParseNextCommand(Lexer: TMYLDBLexer): Boolean;

    // add SELECT query object
    procedure AddSelectQuery(Lexer: TMYLDBLexer);
    // add INSERT query object
    procedure AddInsertQuery(Lexer: TMYLDBLexer);
    // add UPDATE query object
    procedure AddUpdateQuery(Lexer: TMYLDBLexer);
    // add DELETE query object
    procedure AddDeleteQuery(Lexer: TMYLDBLexer);
    // DDL:
    // add TRUNCATE TABLE
    procedure AddTruncateTableQuery(Lexer: TMYLDBLexer);
    // add CREATE TABLE query object
    procedure AddCreateTableQuery(Lexer: TMYLDBLexer);
    // add DROP TABLE query object
    procedure AddDropTableQuery(Lexer: TMYLDBLexer);
    // add ALTER TABLE
    procedure AddAlterTableQuery(Lexer: TMYLDBLexer);
    // add RENAME TABLE
    procedure AddRenameTableQuery(Lexer: TMYLDBLexer);
    // add CREATE INDEX
    procedure AddCreateIndex(Lexer: TMYLDBLexer);
    // add DROP INDEX
    procedure AddDropIndexQuery(Lexer: TMYLDBLexer);
    // add START TRANSACTION
    procedure AddStartTransaction(Lexer: TMYLDBLexer);
    // add COMMIT
    procedure AddCommit(Lexer: TMYLDBLexer);
    // add ROLLBACK
    procedure AddRollback(Lexer: TMYLDBLexer);

    procedure ClearQueries;

   public
    constructor Create(Query: TDataSet);
    destructor Destroy; override;

    function OpenQuery: TMYLDBCursor;
    procedure ExecuteQuery;

    procedure PrepareStatement(SQLText: PChar);

   public
    property ReadOnly: Boolean read FReadOnly write FReadOnly;
    property RequestLive: Boolean read FRequestLive write FRequestLive;
    property InMemory: Boolean read FInMemory write FInMemory;
    property RowsAffected: TMYLDBRecordNo read FRowsAffected;
    property SQLParams: TMYLDBSQLParams read FSQLParams;
  end; // TMYLDBSQLProcessor



////////////////////////////////////////////////////////////////////////////////
//
// TMYLDBSQLSelect
//
////////////////////////////////////////////////////////////////////////////////


 TMYLDBSQLSelect = class (TMYLDBSQLCursorCommand)
  protected
   Distinct:              Boolean; // ALL | DISTINCT
   TopRowCount:           Integer; // TOP (-1 | n)
   FirstRowNo:            Integer; // TOP row count [, first row]
   AllFields:             Boolean; // Select *
   SelectList:            array of TMYLDBSelectListItem; // fields list
   SelectListCount:       integer; // count of array elements
   FromTables:            array of TMYLDBTableReference; // From clause
   FromTablesCount:       integer; // count of array elements
   SearchCondition:       TMYLDBExpression;  // WHERE clause
   GroupByFields:         TMYLDBFields; // GROUP BY field1, f2, ...
   HavingCondition:       TMYLDBExpression;  // HAVING clause
   FSubqueryHasNotAppliedConditions: Boolean;

   // parse SELECT token
   function ParseSelectToken: Boolean;
   // DISTINCT | ALL ?
   function ParseSetQuantifier: Boolean;
   // TOP n ?
   function ParseTopOperator: Boolean;
   function DuplicatedFieldExists(const TableName, FieldName: String): Boolean;
   function FieldExists(const TableName, FieldName: String): Boolean;
   function GetFieldNameForDuplicatedField(const TableName, FieldName: String): String;
   // table1.* | Table1.Field1 | Fields1 AS F1
   function ParseSelectSubList: Boolean;
   // * | <select sublist>
   function ParseSelectList: Boolean;
   // INTO <target>
   function ParseInto: Boolean;
   // ON <join condition>
   function ParseJoinCondition(var SearchCondition: TMYLDBExpression): Boolean;
   // USING <join columns>
   function ParseNamedColumnsJoin(var Fields: TStringList): Boolean;
   // CROSS JOIN | INNER JOIN | ...
   function ParseJoin(var tblRef: TMYLDBTableReference): Boolean;
   // Subquery: SELECT FROM (SELECT ...)
   function ParseFromSubquery(tblRef: TMYLDBTableReference): Boolean;
   // <table name> [ [ AS ] <correlation name> ...
   function ParseTableReference(tblRef: TMYLDBTableReference=nil): Boolean;
   // FROM ...
   function ParseFromClause: Boolean;
   // WHERE ...
   function ParseWhereClause: Boolean;
   // GROUP BY ...
   function ParseGroupByClause: Boolean;
   // HAVING ...
   function ParseHavingClause: Boolean;

   // gets default database name
   function GetDefaultDatabaseName: string;
   // gets DisableTempFiles value
   function GetDisableTempFiles: boolean;
   // creates and adjusts table AO
   function CreateTableAO(var TableRef: TMYLDBTableReference): TMYLDBAO;
   // creates and adjusts joined table AO
   function CreateJoinedTableAO(var TableRef: TMYLDBTableReference;
                       ParentQueryAO: TMYLDBAO; ParentCursor: TMYLDBCursor;
                       AllowNotAppliedConditions: Boolean): TMYLDBAO;
   // creates and adjusts subquery AO
   function CreateSubQueryAO(var TableRef: TMYLDBTableReference; RequestLive: Boolean;
                             ParentQueryAO: TMYLDBAO; ParentCursor: TMYLDBCursor;
                             AllowNotAppliedConditions: Boolean): TMYLDBAO;
   // creates and adjusts AO
   function CreateAO(var TableRef: TMYLDBTableReference; RequestLive: Boolean;
          ParentQueryAO: TMYLDBAO;
          ParentCursor: TMYLDBCursor; AllowNotAppliedConditions: Boolean): TMYLDBAO;
   // builds one-table AO
   function BuildOneTableTree(RequestLive: Boolean; ParentQueryAO: TMYLDBAO;
          ParentCursor: TMYLDBCursor; AllowNotAppliedConditions: Boolean): TMYLDBAO;
   // builds multi-tables AO tree
   function BuildMultiTablesTree(RequestLive: Boolean; ParentQueryAO: TMYLDBAO;
          ParentCursor: TMYLDBCursor; AllowNotAppliedConditions: Boolean): TMYLDBAO;
  public
   // creates object
   constructor Create(Lexer: TMYLDBLexer; Query: TDataSet);
   // destroys object
   destructor Destroy; override;
   // parses query
   procedure Parse; override;
   // check if correlated subquery apllied
   function AllConditionsApplied: Boolean; override;
   // builds AO tree
   function BuildAOTree(query: TDataset; RequestLive: Boolean; ParentQueryAO: TMYLDBAO;
                      ParentCursor: TMYLDBCursor; AllowNotAppliedConditions: Boolean): TMYLDBAO; override;
 end;//TMYLDBSQLSelect



////////////////////////////////////////////////////////////////////////////////
//
// TMYLDBQueryExprNode
//
////////////////////////////////////////////////////////////////////////////////

 // select | union | except | ...
 TMYLDBQueryExprNode = class (TObject)
  NodeType:         TMYLDBQueryExprType;  // node is: select | union | except | ...
  Left:             TMYLDBQueryExprNode;  // left node in union, except, ...
  Right:            TMYLDBQueryExprNode;  // right table in union, except, ...
  All:              Boolean;            // [ALL] specified?
  Corresponding:    Boolean;            // [CORRESPONDING] specified?
  CorrespondingFields: TStringList;     // column list
  SelectCommand:    TMYLDBSQLSelect;      // SELECT command (if NodeType is select)

  // creates
  constructor Create; overload;
  // creates copy
  constructor Create(Src: TMYLDBQueryExprNode); overload;
  // destroys

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色综合中文综合网| 在线欧美一区二区| 精品一区二区在线免费观看| 亚洲综合免费观看高清完整版 | 欧美一区二区三区四区五区| 日本电影亚洲天堂一区| 日本精品视频一区二区三区| 色哟哟欧美精品| 欧美日韩一区小说| 欧美一区二区三区在线| 精品国产伦一区二区三区观看方式| 日韩欧美中文字幕公布| 免费观看在线综合色| 一区二区三区四区乱视频| 亚洲色图.com| 婷婷国产v国产偷v亚洲高清| 亚洲自拍偷拍综合| 毛片一区二区三区| 高清不卡在线观看| 91原创在线视频| 91成人在线精品| 欧美一级片免费看| 国产午夜精品久久久久久久| 亚洲欧洲日产国产综合网| 亚洲福利一区二区| 免费在线欧美视频| 欧美成人性战久久| 欧美日韩一区二区三区免费看| 国产成人免费9x9x人网站视频| 国产一区二区三区在线观看免费| 精彩视频一区二区| 国产99精品视频| 欧美色区777第一页| 制服丝袜亚洲色图| 中文字幕不卡的av| 五月综合激情网| 成人午夜电影小说| 4438x亚洲最大成人网| 国产精品天美传媒| 日本va欧美va瓶| 99国产精品国产精品久久| 日韩精品专区在线| 一区在线播放视频| 美国欧美日韩国产在线播放| 一本一本大道香蕉久在线精品| 欧美成人激情免费网| 一区二区三区欧美日韩| 国产乱国产乱300精品| 欧美天堂一区二区三区| 久久精品亚洲一区二区三区浴池| 一区二区三区美女视频| 国产成a人无v码亚洲福利| 宅男噜噜噜66一区二区66| 亚洲欧洲99久久| 国精产品一区一区三区mba桃花| 欧美怡红院视频| 国产精品国产精品国产专区不蜜| 日韩二区三区在线观看| 欧美在线观看禁18| 国产精品福利在线播放| 久久国产精品免费| 91福利视频在线| 亚洲欧美另类久久久精品| 精品在线观看免费| 欧美日韩成人激情| 午夜婷婷国产麻豆精品| 在线观看一区二区精品视频| 国产精品久久夜| 丰满少妇久久久久久久| 久久伊人蜜桃av一区二区| 美女性感视频久久| 欧美一区中文字幕| 蜜臀久久99精品久久久久久9| 一本久久综合亚洲鲁鲁五月天| 久久夜色精品国产噜噜av| 看片的网站亚洲| 欧美一区二区不卡视频| 自拍偷拍欧美精品| 成人爱爱电影网址| 国产精品欧美综合在线| 成人自拍视频在线| 久久精品一区二区| 高清不卡一区二区| 中文字幕一区二| 99热99精品| 亚洲精品国产精品乱码不99| 在线观看视频91| 一区二区三区国产| 在线观看91精品国产麻豆| 日韩黄色片在线观看| 日韩一区二区电影网| 另类小说色综合网站| 久久久久久久综合日本| 99久久99久久久精品齐齐| 亚洲三级久久久| 在线不卡一区二区| 国产精品一区一区| 亚洲人妖av一区二区| 欧美日韩成人综合天天影院 | www国产精品av| 国产成人在线视频播放| 国产精品久久久久久久久久久免费看 | 中文字幕乱码久久午夜不卡| 91蜜桃视频在线| 强制捆绑调教一区二区| 久久精品人人做| 色婷婷综合中文久久一本| 日韩精品欧美精品| 国产情人综合久久777777| av一区二区三区四区| 亚洲一区二区三区四区的| 精品久久一二三区| 91亚洲国产成人精品一区二三| 五月激情六月综合| 国产日本亚洲高清| 欧美丰满少妇xxxbbb| 波多野结衣在线一区| 视频一区欧美日韩| 中文字幕日本不卡| 欧美一级片在线看| 99热精品一区二区| 美女视频黄 久久| 一区二区三区免费网站| 久久久久国产精品麻豆| 欧美日本乱大交xxxxx| 国产精品综合久久| 免费成人在线视频观看| 亚洲女爱视频在线| 久久精品免费在线观看| 91麻豆精品久久久久蜜臀| av不卡免费电影| 国产伦精品一区二区三区免费迷 | jizzjizzjizz欧美| 免费成人在线视频观看| 日韩毛片精品高清免费| 国产亚洲女人久久久久毛片| 91精品国产综合久久久久久| 一本大道久久a久久综合婷婷| 国产精品一二三四五| 日本伊人精品一区二区三区观看方式| 中文字幕亚洲欧美在线不卡| 久久精品亚洲国产奇米99| 欧美大胆人体bbbb| 91精品免费观看| 欧美三级电影在线看| 91首页免费视频| 国产成人精品一区二区三区网站观看| 免费观看一级特黄欧美大片| 全部av―极品视觉盛宴亚洲| 亚洲成人你懂的| 亚洲一区精品在线| 亚洲一区视频在线观看视频| 亚洲一区国产视频| 亚洲一区中文在线| 午夜私人影院久久久久| 天涯成人国产亚洲精品一区av| 亚洲与欧洲av电影| 日韩精品久久久久久| 亚洲自拍偷拍图区| 亚洲成人自拍网| 国产精品久久久久久久久免费桃花 | 捆绑紧缚一区二区三区视频| 日韩精品亚洲一区| 久久激情五月婷婷| 国产一区二区三区香蕉| 国产高清亚洲一区| 99久久精品情趣| 色婷婷精品大在线视频| 欧美性受极品xxxx喷水| 欧美精品1区2区3区| 日韩精品一区二区三区中文不卡| 欧美一级免费大片| 国产视频亚洲色图| 亚洲欧美日韩国产一区二区三区| 亚洲综合一区二区精品导航| 日本午夜一区二区| 国产精品一区二区无线| jlzzjlzz欧美大全| 91精品久久久久久蜜臀| 精品处破学生在线二十三| 国产精品无人区| 亚洲图片有声小说| 久久99精品一区二区三区三区| 国产成人av一区| 欧美在线视频不卡| 精品美女在线播放| 亚洲视频在线一区二区| 丝袜亚洲另类欧美| 成人午夜在线视频| 制服丝袜成人动漫| 欧美国产视频在线| 日韩高清在线不卡| 成人福利视频网站| 日韩网站在线看片你懂的| 国产精品欧美极品| 日韩av不卡一区二区| av一区二区久久| 久久一区二区三区四区| 午夜精品久久久久久久久久| 国产成人免费在线观看|