#pragma once #include #include namespace DB { /** Вложенная таблица. Например, Nested(UInt32 CounterID, FixedString(2) UserAgentMajor) */ class ParserNestedTable : public IParserBase { protected: String getName() { return "nested table"; } bool parseImpl(Pos & pos, Pos end, ASTPtr & node, String & expected); }; /** Параметрический тип или Storage. Например: * FixedString(10) или * Partitioned(Log, ChunkID) или * Nested(UInt32 CounterID, FixedString(2) UserAgentMajor) * Результат парсинга - ASTFunction с параметрами или без. */ class ParserIdentifierWithParameters : public IParserBase { protected: String getName() { return "identifier with parameters"; } bool parseImpl(Pos & pos, Pos end, ASTPtr & node, String & expected); }; /** Тип или Storage, возможно, параметрический. Например, UInt8 или примеры из ParserIdentifierWithParameters * Результат парсинга - ASTFunction с параметрами или без. */ class ParserIdentifierWithOptionalParameters : public IParserBase { protected: String getName() { return "identifier with optional parameters"; } bool parseImpl(Pos & pos, Pos end, ASTPtr & node, String & expected); }; /** Имя и тип через пробел. Например, URL String. */ class ParserNameTypePair : public IParserBase { protected: String getName() { return "name and type pair"; } bool parseImpl(Pos & pos, Pos end, ASTPtr & node, String & expected); }; /** Список столбцов. */ class ParserNameTypePairList : public IParserBase { protected: String getName() { return "name and type pair list"; } bool parseImpl(Pos & pos, Pos end, ASTPtr & node, String & expected); }; /** ENGINE = name. */ class ParserEngine : public IParserBase { protected: String getName() { return "ENGINE"; } bool parseImpl(Pos & pos, Pos end, ASTPtr & node, String & expected); }; /** Запрос типа такого: * CREATE|ATTACH TABLE [IF NOT EXISTS] [db.]name * ( * name1 type1, * name2 type2, * ... * ) ENGINE = engine * * Или: * CREATE|ATTACH TABLE [IF NOT EXISTS] [db.]name AS [db2.]name2 [ENGINE = engine] * * Или: * CREATE|ATTACH TABLE [IF NOT EXISTS] [db.]name AS ENGINE = engine SELECT ... * * Или: * CREATE|ATTACH DATABASE db */ class ParserCreateQuery : public IParserBase { protected: String getName() { return "CREATE TABLE or ATTACH TABLE query"; } bool parseImpl(Pos & pos, Pos end, ASTPtr & node, String & expected); }; }