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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? myldbsqlprocessor.pas

?? 一個本地database引擎,支持中文T_Sql查詢,兼容DELPHI標(biāo)準(zhǔn)數(shù)據(jù)庫控件
?? 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

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
奇米888四色在线精品| 欧美剧在线免费观看网站| 成人免费视频在线观看| 91在线精品一区二区三区| 亚洲激情图片一区| 欧美一区二区三区在线观看视频 | 亚洲精品视频一区二区| 一本大道av伊人久久综合| 亚洲一区二区高清| 日韩欧美一区二区久久婷婷| 国产成人亚洲综合a∨猫咪| 18涩涩午夜精品.www| 日本韩国一区二区| 日本午夜一本久久久综合| 精品粉嫩aⅴ一区二区三区四区| 成人一级视频在线观看| 亚洲男人的天堂在线观看| 欧美日韩你懂的| 国产最新精品精品你懂的| 亚洲欧洲成人自拍| 欧美精品丝袜久久久中文字幕| 九一久久久久久| 一色桃子久久精品亚洲| 欧美久久高跟鞋激| 国产精品一区2区| 亚洲精品欧美专区| 欧美一区二区三区的| 高清日韩电视剧大全免费| 亚洲亚洲人成综合网络| 精品国产a毛片| 一本大道久久a久久综合| 麻豆国产精品一区二区三区 | 日韩一级免费观看| 高清久久久久久| 亚洲18影院在线观看| 久久久欧美精品sm网站| 欧美日韩专区在线| 国产精品18久久久久久vr| 亚洲一区二区三区四区在线免费观看| 欧美成人精品福利| 91视频在线看| 久久99精品国产| 亚洲一区二区三区视频在线播放| 久久欧美中文字幕| 色伊人久久综合中文字幕| 精品一区二区三区在线播放| 夜夜亚洲天天久久| 久久精品欧美一区二区三区不卡 | 免费在线看成人av| 国产精品黄色在线观看| 欧美一区二区三区视频在线观看 | 国产欧美日韩精品一区| 欧美丰满一区二区免费视频| 成人精品免费视频| 美女视频黄频大全不卡视频在线播放| 国产精品毛片大码女人| 精品久久久影院| 在线欧美一区二区| 高清成人免费视频| 久久成人麻豆午夜电影| 一区二区三区自拍| 欧美国产欧美综合| 精品日韩一区二区三区| 欧美日韩一区二区欧美激情| heyzo一本久久综合| 精彩视频一区二区三区| 亚洲成在线观看| 亚洲人成在线观看一区二区| 国产日韩欧美精品综合| 欧美高清一级片在线| 色视频一区二区| 成人精品在线视频观看| 国产麻豆日韩欧美久久| 蜜臀国产一区二区三区在线播放| 亚洲线精品一区二区三区 | 国产精品短视频| 久久久午夜精品理论片中文字幕| 91精品国产91久久久久久一区二区| 91香蕉国产在线观看软件| 国产伦精品一区二区三区免费| 免费在线观看日韩欧美| 午夜精品一区二区三区三上悠亚| 亚洲欧美日韩在线不卡| 国产精品免费人成网站| 国产色产综合产在线视频| 欧美一级免费观看| 欧美日韩dvd在线观看| 欧美亚洲动漫精品| 色94色欧美sute亚洲线路一ni| 不卡一区在线观看| 东方欧美亚洲色图在线| 国产精品综合二区| 国产在线精品国自产拍免费| 免费日本视频一区| 日本成人在线不卡视频| 婷婷国产在线综合| 日韩中文字幕一区二区三区| 亚洲国产精品视频| 午夜精品久久久久久久99樱桃| 亚洲国产精品久久艾草纯爱| 一区二区三区欧美久久| 一区二区三区在线播| 一二三区精品福利视频| 亚洲国产日韩精品| 五月天激情综合网| 日韩精品午夜视频| 秋霞国产午夜精品免费视频| 蜜臀99久久精品久久久久久软件| 蜜臀久久久99精品久久久久久| 久久99精品国产91久久来源| 激情欧美日韩一区二区| 国产乱码精品一品二品| 懂色av一区二区在线播放| 99久久免费精品| 91久久精品一区二区三区| 欧美婷婷六月丁香综合色| 欧美剧情电影在线观看完整版免费励志电影| 欧美日韩成人综合天天影院| 欧美一区二区播放| 精品国产乱码久久久久久夜甘婷婷| 精品国产凹凸成av人导航| 亚洲国产电影在线观看| 日韩一区欧美一区| 亚洲国产视频a| 麻豆国产精品官网| 国产成人午夜精品影院观看视频 | 欧美一区二区免费| 精品成人一区二区| 国产精品美女久久久久久久久久久 | 中文字幕一区在线观看视频| 最新高清无码专区| 亚洲成人自拍网| 久久99精品国产.久久久久| 国产成人精品影视| 色偷偷一区二区三区| 欧美美女网站色| 久久久久久久综合| 亚洲视频在线一区| 日韩高清不卡一区二区| 国产乱人伦精品一区二区在线观看| av毛片久久久久**hd| 欧美日本一区二区三区| 精品国产污污免费网站入口| 国产精品第四页| 亚洲成a人v欧美综合天堂下载| 老汉av免费一区二区三区 | 久久精品亚洲国产奇米99| 中文字幕巨乱亚洲| 亚洲国产美女搞黄色| 久久69国产一区二区蜜臀| 不卡欧美aaaaa| 欧美绝品在线观看成人午夜影视| 久久久久久毛片| 洋洋成人永久网站入口| 久久99久久久欧美国产| 成人ar影院免费观看视频| 欧美日韩国产在线观看| 久久久激情视频| 亚洲午夜精品在线| 国产激情精品久久久第一区二区 | 欧美人与z0zoxxxx视频| 久久久久青草大香线综合精品| 亚洲精品亚洲人成人网在线播放| 日韩1区2区日韩1区2区| av激情亚洲男人天堂| 日韩一区二区免费视频| 国产精品伦理一区二区| 免费看日韩精品| 95精品视频在线| 亚洲精品一区二区三区蜜桃下载| 亚洲精品乱码久久久久久黑人| 九九精品一区二区| 91久久国产综合久久| 久久久久久久久一| 亚洲6080在线| av爱爱亚洲一区| 欧美精品一区男女天堂| 亚洲一区二区三区在线看| 高清shemale亚洲人妖| 9191国产精品| 亚洲嫩草精品久久| 黑人精品欧美一区二区蜜桃 | 国产精品福利电影一区二区三区四区| 秋霞影院一区二区| 一本久久a久久精品亚洲| 久久影院午夜论| 视频一区国产视频| 色婷婷综合久久久中文一区二区| 久久精品免费在线观看| 男男gaygay亚洲| 欧美日韩综合一区| 亚洲欧美日韩国产成人精品影院| 国产精品一区二区久激情瑜伽| 欧美巨大另类极品videosbest| 亚洲欧美国产77777| 成人午夜av电影| 26uuu色噜噜精品一区| 日韩制服丝袜av| 91久久国产最好的精华液| 国产精品久久影院|