mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-02 12:32:04 +00:00
5fc44df6b5
commit f9b478181cd49224154cc350fb57df7121842f1c Author: Alexey Milovidov <milovidov@yandex-team.ru> Date: Sat Mar 19 04:06:36 2016 +0300 Database engines: development [#METR-19997]. commit f7a10a67761ccfd05f3dac32d6444920cd8d4d60 Author: Alexey Milovidov <milovidov@yandex-team.ru> Date: Sat Mar 19 03:44:37 2016 +0300 Database engines: development [#METR-19997]. commit bd98a8558e98bad2bed278e5762c4e0fc66e6f38 Author: Alexey Milovidov <milovidov@yandex-team.ru> Date: Sat Mar 19 00:33:59 2016 +0300 Database engines: development [#METR-19997]. commit 19712fd884c22a4e2c2b67474086dea8f44e7c7b Author: Alexey Milovidov <milovidov@yandex-team.ru> Date: Sat Mar 19 00:03:11 2016 +0300 Database engines: development [#METR-19997]. commit 50274d6df7e91fcc34aab8a8c72347daa2c6512f Author: Alexey Milovidov <milovidov@yandex-team.ru> Date: Fri Mar 18 23:24:57 2016 +0300 Database engines: development [#METR-19997]. commit 4a0b99b19b34e90ef8b7be2d199f6232e36ef3f7 Author: Alexey Milovidov <milovidov@yandex-team.ru> Date: Fri Mar 18 22:50:36 2016 +0300 Database engines: development [#METR-19997]. commit 44ff3ebba7a3e460a27a89f31ddf199dbea1d182 Author: Alexey Milovidov <milovidov@yandex-team.ru> Date: Fri Mar 18 15:09:17 2016 +0300 Database engines: development [#METR-19997]. commit 137c31f3004cfd282473b6acb01cbe1b4ca2aadd Author: Alexey Milovidov <milovidov@yandex-team.ru> Date: Fri Mar 18 03:26:34 2016 +0300 Database engines: development [#METR-19997]. commit aa4c0496d4afe4a691164254be2bd5600542b38a Author: Alexey Milovidov <milovidov@yandex-team.ru> Date: Fri Mar 18 03:22:59 2016 +0300 Database engines: development [#METR-19997]. commit 5a94d1f0607450a2dac28a4d7df8b1393a864c23 Author: Alexey Milovidov <milovidov@yandex-team.ru> Date: Fri Mar 18 01:02:40 2016 +0300 Database engines: development [#METR-19997]. commit 50fd5b52ea1141955a5dfba0dcb191f3289ac25b Author: Alexey Milovidov <milovidov@yandex-team.ru> Date: Thu Mar 17 23:23:40 2016 +0300 Database engines: development [#METR-19997]. commit a333d91b058e4f56dd83a6d2878c3c2bd8efc002 Author: Alexey Milovidov <milovidov@yandex-team.ru> Date: Thu Mar 17 20:29:07 2016 +0300 Database engines: development [#METR-19997]. commit f81d366e7ac8348436f2698d040f8e341743a024 Author: Alexey Milovidov <milovidov@yandex-team.ru> Date: Thu Mar 17 01:30:23 2016 +0300 Database engines: development [#METR-19997]. commit d0696860c9060827896214c08d147c759ea79376 Author: Alexey Milovidov <milovidov@yandex-team.ru> Date: Wed Mar 16 21:55:31 2016 +0300 Database engines: development [#METR-19997]. commit 46a168c2ada140a0e95cd8d4b9d8ba9bac855d11 Author: Alexey Milovidov <milovidov@yandex-team.ru> Date: Wed Mar 16 08:00:58 2016 +0300 Database engines: development [#METR-19997]. commit 20a2bad161454225fc1b5f9b919b842fbebc3231 Author: Alexey Milovidov <milovidov@yandex-team.ru> Date: Wed Mar 16 06:51:10 2016 +0300 Database engines: development [#METR-19997]. commit ca0a77fcc2a8d0b276eb3743c53551ad3fe16314 Author: Alexey Milovidov <milovidov@yandex-team.ru> Date: Wed Mar 16 06:02:20 2016 +0300 Reverted erroneous modification [#METR-19997]. commit 1370bdcc4594182f6ef2b146f9afabfe1c295080 Author: Alexey Milovidov <milovidov@yandex-team.ru> Date: Wed Mar 16 00:41:34 2016 +0300 Database engines: development [#METR-19997]. commit 16e72c67041cae6471509d3f0f3d4a9aa7b7dc0f Author: Alexey Milovidov <milovidov@yandex-team.ru> Date: Tue Mar 15 00:41:48 2016 +0300 Database engines: development [#METR-19997].
234 lines
7.5 KiB
C++
234 lines
7.5 KiB
C++
#pragma once
|
||
|
||
#include <DB/Parsers/IParserBase.h>
|
||
#include <DB/Parsers/ExpressionElementParsers.h>
|
||
#include <DB/Parsers/ExpressionListParsers.h>
|
||
#include <DB/Parsers/ASTNameTypePair.h>
|
||
#include <DB/Parsers/ASTColumnDeclaration.h>
|
||
#include <DB/Parsers/ASTIdentifier.h>
|
||
#include <DB/Parsers/CommonParsers.h>
|
||
#include <Poco/String.h>
|
||
|
||
|
||
namespace DB
|
||
{
|
||
|
||
/** Вложенная таблица. Например, Nested(UInt32 CounterID, FixedString(2) UserAgentMajor)
|
||
*/
|
||
class ParserNestedTable : public IParserBase
|
||
{
|
||
protected:
|
||
const char * getName() const { return "nested table"; }
|
||
bool parseImpl(Pos & pos, Pos end, ASTPtr & node, Pos & max_parsed_pos, Expected & expected);
|
||
};
|
||
|
||
|
||
/** Параметрический тип или Storage. Например:
|
||
* FixedString(10) или
|
||
* Partitioned(Log, ChunkID) или
|
||
* Nested(UInt32 CounterID, FixedString(2) UserAgentMajor)
|
||
* Результат парсинга - ASTFunction с параметрами или без.
|
||
*/
|
||
class ParserIdentifierWithParameters : public IParserBase
|
||
{
|
||
protected:
|
||
const char * getName() const { return "identifier with parameters"; }
|
||
bool parseImpl(Pos & pos, Pos end, ASTPtr & node, Pos & max_parsed_pos, Expected & expected);
|
||
};
|
||
|
||
|
||
/** Тип или Storage, возможно, параметрический. Например, UInt8 или примеры из ParserIdentifierWithParameters
|
||
* Результат парсинга - ASTFunction с параметрами или без.
|
||
*/
|
||
class ParserIdentifierWithOptionalParameters : public IParserBase
|
||
{
|
||
protected:
|
||
const char * getName() const { return "identifier with optional parameters"; }
|
||
bool parseImpl(Pos & pos, Pos end, ASTPtr & node, Pos & max_parsed_pos, Expected & expected);
|
||
};
|
||
|
||
class ParserTypeInCastExpression : public ParserIdentifierWithOptionalParameters
|
||
{
|
||
protected:
|
||
const char * getName() const { return "type in cast expression"; }
|
||
bool parseImpl(Pos & pos, Pos end, ASTPtr & node, Pos & max_parsed_pos, Expected & expected);
|
||
};
|
||
|
||
|
||
template <class NameParser>
|
||
class IParserNameTypePair : public IParserBase
|
||
{
|
||
protected:
|
||
const char * getName() const { return "name and type pair"; }
|
||
bool parseImpl(Pos & pos, Pos end, ASTPtr & node, Pos & max_parsed_pos, Expected & expected);
|
||
};
|
||
|
||
/** Имя и тип через пробел. Например, URL String. */
|
||
typedef IParserNameTypePair<ParserIdentifier> ParserNameTypePair;
|
||
/** Имя и тип через пробел. Имя может содержать точку. Например, Hits.URL String. */
|
||
typedef IParserNameTypePair<ParserCompoundIdentifier> ParserCompoundNameTypePair;
|
||
|
||
template <class NameParser>
|
||
bool IParserNameTypePair<NameParser>::parseImpl(Pos & pos, Pos end, ASTPtr & node, Pos & max_parsed_pos, Expected & expected)
|
||
{
|
||
NameParser name_parser;
|
||
ParserIdentifierWithOptionalParameters type_parser;
|
||
ParserWhiteSpaceOrComments ws_parser;
|
||
|
||
Pos begin = pos;
|
||
|
||
ASTPtr name, type;
|
||
if (name_parser.parse(pos, end, name, max_parsed_pos, expected)
|
||
&& ws_parser.ignore(pos, end, max_parsed_pos, expected)
|
||
&& type_parser.parse(pos, end, type, max_parsed_pos, expected))
|
||
{
|
||
ASTNameTypePair * name_type_pair = new ASTNameTypePair(StringRange(begin, pos));
|
||
node = name_type_pair;
|
||
name_type_pair->name = typeid_cast<ASTIdentifier &>(*name).name;
|
||
name_type_pair->type = type;
|
||
name_type_pair->children.push_back(type);
|
||
return true;
|
||
}
|
||
|
||
return false;
|
||
}
|
||
|
||
/** Список столбцов. */
|
||
class ParserNameTypePairList : public IParserBase
|
||
{
|
||
protected:
|
||
const char * getName() const { return "name and type pair list"; }
|
||
bool parseImpl(Pos & pos, Pos end, ASTPtr & node, Pos & max_parsed_pos, Expected & expected);
|
||
};
|
||
|
||
|
||
template <class NameParser>
|
||
class IParserColumnDeclaration : public IParserBase
|
||
{
|
||
protected:
|
||
const char * getName() const { return "column declaration"; }
|
||
bool parseImpl(Pos & pos, Pos end, ASTPtr & node, Pos & max_parsed_pos, Expected & expected);
|
||
};
|
||
|
||
typedef IParserColumnDeclaration<ParserIdentifier> ParserColumnDeclaration;
|
||
typedef IParserColumnDeclaration<ParserCompoundIdentifier> ParserCompoundColumnDeclaration;
|
||
|
||
template <class NameParser>
|
||
bool IParserColumnDeclaration<NameParser>::parseImpl(Pos & pos, Pos end, ASTPtr & node, Pos & max_parsed_pos, Expected & expected)
|
||
{
|
||
NameParser name_parser;
|
||
ParserIdentifierWithOptionalParameters type_parser;
|
||
ParserWhiteSpaceOrComments ws;
|
||
ParserString s_default{"DEFAULT", true, true};
|
||
ParserString s_materialized{"MATERIALIZED", true, true};
|
||
ParserString s_alias{"ALIAS", true, true};
|
||
ParserTernaryOperatorExpression expr_parser;
|
||
|
||
const auto begin = pos;
|
||
|
||
/// mandatory column name
|
||
ASTPtr name;
|
||
if (!name_parser.parse(pos, end, name, max_parsed_pos, expected))
|
||
return false;
|
||
|
||
ws.ignore(pos, end, max_parsed_pos, expected);
|
||
|
||
/** column name should be followed by type name if it
|
||
* is not immediately followed by {DEFAULT, MATERIALIZED, ALIAS}
|
||
*/
|
||
ASTPtr type;
|
||
const auto fallback_pos = pos;
|
||
if (!s_default.check(pos, end, expected, max_parsed_pos) &&
|
||
!s_materialized.check(pos, end, expected, max_parsed_pos) &&
|
||
!s_alias.check(pos, end, expected, max_parsed_pos))
|
||
{
|
||
if (type_parser.parse(pos, end, type, max_parsed_pos, expected))
|
||
ws.ignore(pos, end, max_parsed_pos, expected);
|
||
}
|
||
else
|
||
pos = fallback_pos;
|
||
|
||
/// parse {DEFAULT, MATERIALIZED, ALIAS}
|
||
String default_specifier;
|
||
ASTPtr default_expression;
|
||
const auto pos_before_specifier = pos;
|
||
if (s_default.ignore(pos, end, max_parsed_pos, expected) ||
|
||
s_materialized.ignore(pos, end, max_parsed_pos, expected) ||
|
||
s_alias.ignore(pos, end, max_parsed_pos, expected))
|
||
{
|
||
default_specifier = Poco::toUpper(std::string{pos_before_specifier, pos});
|
||
|
||
/// should be followed by an expression
|
||
ws.ignore(pos, end, max_parsed_pos, expected);
|
||
|
||
if (!expr_parser.parse(pos, end, default_expression, max_parsed_pos, expected))
|
||
return false;
|
||
}
|
||
else if (!type)
|
||
return false; /// reject sole column name without type
|
||
|
||
const auto column_declaration = new ASTColumnDeclaration{StringRange{begin, pos}};
|
||
node = column_declaration;
|
||
column_declaration->name = typeid_cast<ASTIdentifier &>(*name).name;
|
||
if (type)
|
||
{
|
||
column_declaration->type = type;
|
||
column_declaration->children.push_back(std::move(type));
|
||
}
|
||
|
||
if (default_expression)
|
||
{
|
||
column_declaration->default_specifier = default_specifier;
|
||
column_declaration->default_expression = default_expression;
|
||
column_declaration->children.push_back(std::move(default_expression));
|
||
}
|
||
|
||
return true;
|
||
}
|
||
|
||
class ParserColumnDeclarationList : public IParserBase
|
||
{
|
||
protected:
|
||
const char * getName() const { return "column declaration list"; }
|
||
bool parseImpl(Pos & pos, Pos end, ASTPtr & node, Pos & max_parsed_pos, Expected & expected);
|
||
};
|
||
|
||
|
||
/** ENGINE = name. */
|
||
class ParserEngine : public IParserBase
|
||
{
|
||
protected:
|
||
const char * getName() const { return "ENGINE"; }
|
||
bool parseImpl(Pos & pos, Pos end, ASTPtr & node, Pos & max_parsed_pos, Expected & 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 [ENGINE = engine]
|
||
*
|
||
* Или:
|
||
* CREATE|ATTACH [MATERIALIZED] VIEW [IF NOT EXISTS] [db.]name [ENGINE = engine] [POPULATE] AS SELECT ...
|
||
*/
|
||
class ParserCreateQuery : public IParserBase
|
||
{
|
||
protected:
|
||
const char * getName() const { return "CREATE TABLE or ATTACH TABLE query"; }
|
||
bool parseImpl(Pos & pos, Pos end, ASTPtr & node, Pos & max_parsed_pos, Expected & expected);
|
||
};
|
||
|
||
}
|