ClickHouse/dbms/src/Parsers/ParserCreateQuery.cpp

429 lines
11 KiB
C++
Raw Normal View History

2011-08-18 18:48:00 +00:00
#include <DB/Parsers/ASTFunction.h>
#include <DB/Parsers/ASTIdentifier.h>
#include <DB/Parsers/ASTExpressionList.h>
#include <DB/Parsers/ASTCreateQuery.h>
#include <DB/Parsers/ExpressionListParsers.h>
#include <DB/Parsers/ParserCreateQuery.h>
2011-11-01 15:16:04 +00:00
#include <DB/Parsers/ParserSelectQuery.h>
2011-08-18 18:48:00 +00:00
namespace DB
{
bool ParserNestedTable::parseImpl(Pos & pos, Pos end, ASTPtr & node, Pos & max_parsed_pos, Expected & expected)
{
ParserWhiteSpaceOrComments ws;
ParserString open("(");
ParserString close(")");
ParserIdentifier name_p;
ParserNameTypePairList columns_p;
ASTPtr name;
ASTPtr columns;
Pos begin = pos;
/// Пока name == 'Nested', возможно потом появятся альтернативные вложенные структуры данных
if (!name_p.parse(pos, end, name, max_parsed_pos, expected))
return false;
ws.ignore(pos, end);
if (!open.ignore(pos, end))
return false;
ws.ignore(pos, end);
if (!columns_p.parse(pos, end, columns, max_parsed_pos, expected))
return false;
ws.ignore(pos, end);
if (!close.ignore(pos, end))
return false;
auto func = std::make_shared<ASTFunction>(StringRange(begin, pos));
func->name = typeid_cast<ASTIdentifier &>(*name).name;
func->arguments = columns;
func->children.push_back(columns);
node = func;
return true;
}
bool ParserIdentifierWithParameters::parseImpl(Pos & pos, Pos end, ASTPtr & node, Pos & max_parsed_pos, Expected & expected)
{
ParserFunction function_or_array;
if (function_or_array.parse(pos, end, node, max_parsed_pos, expected))
return true;
ParserNestedTable nested;
if (nested.parse(pos, end, node, max_parsed_pos, expected))
return true;
return false;
}
2011-08-18 18:48:00 +00:00
bool ParserIdentifierWithOptionalParameters::parseImpl(Pos & pos, Pos end, ASTPtr & node, Pos & max_parsed_pos, Expected & expected)
2011-08-18 18:48:00 +00:00
{
ParserIdentifier non_parametric;
ParserIdentifierWithParameters parametric;
2011-08-18 18:48:00 +00:00
Pos begin = pos;
if (parametric.parse(pos, end, node, max_parsed_pos, expected))
2011-08-18 18:48:00 +00:00
return true;
ASTPtr ident;
if (non_parametric.parse(pos, end, ident, max_parsed_pos, expected))
2011-08-18 18:48:00 +00:00
{
auto func = std::make_shared<ASTFunction>(StringRange(begin, pos));
func->name = typeid_cast<ASTIdentifier &>(*ident).name;
node = func;
2011-08-18 18:48:00 +00:00
return true;
}
return false;
}
bool ParserTypeInCastExpression::parseImpl(Pos & pos, Pos end, ASTPtr & node, Pos & max_parsed_pos, Expected & expected)
{
if (ParserIdentifierWithOptionalParameters::parseImpl(pos, end, node, max_parsed_pos, expected))
{
const auto & id_with_params = typeid_cast<const ASTFunction &>(*node);
node = std::make_shared<ASTIdentifier>(id_with_params.range, { id_with_params.range.first, id_with_params.range.second });
return true;
}
return false;
}
bool ParserNameTypePairList::parseImpl(Pos & pos, Pos end, ASTPtr & node, Pos & max_parsed_pos, Expected & expected)
{
return ParserList(ParserPtr(new ParserNameTypePair), ParserPtr(new ParserString(",")), false).parse(pos, end, node, max_parsed_pos, expected);
}
bool ParserColumnDeclarationList::parseImpl(Pos & pos, Pos end, ASTPtr & node, Pos & max_parsed_pos, Expected & expected)
{
return ParserList{ParserPtr{new ParserColumnDeclaration}, ParserPtr{new ParserString{","}}, false}.parse(pos, end, node, max_parsed_pos, expected);
}
bool ParserEngine::parseImpl(Pos & pos, Pos end, ASTPtr & node, Pos & max_parsed_pos, Expected & expected)
2011-11-01 15:16:04 +00:00
{
ParserWhiteSpaceOrComments ws;
2011-11-05 23:31:19 +00:00
ParserString s_engine("ENGINE", true, true);
2011-11-01 15:16:04 +00:00
ParserString s_eq("=");
ParserIdentifierWithOptionalParameters storage_p;
ws.ignore(pos, end);
if (s_engine.ignore(pos, end, max_parsed_pos, expected))
2011-11-01 15:16:04 +00:00
{
ws.ignore(pos, end);
if (!s_eq.ignore(pos, end, max_parsed_pos, expected))
2011-11-01 15:16:04 +00:00
return false;
ws.ignore(pos, end);
if (!storage_p.parse(pos, end, node, max_parsed_pos, expected))
2011-11-01 15:16:04 +00:00
return false;
ws.ignore(pos, end);
}
return true;
}
bool ParserCreateQuery::parseImpl(Pos & pos, Pos end, ASTPtr & node, Pos & max_parsed_pos, Expected & expected)
2011-08-18 18:48:00 +00:00
{
Pos begin = pos;
ParserWhiteSpaceOrComments ws;
ParserString s_create("CREATE", true, true);
ParserString s_temporary("TEMPORARY", true, true);
2011-08-18 18:48:00 +00:00
ParserString s_attach("ATTACH", true, true);
ParserString s_table("TABLE", true, true);
2011-11-05 23:31:19 +00:00
ParserString s_database("DATABASE", true, true);
2011-10-30 05:19:41 +00:00
ParserString s_dot(".");
2011-08-18 18:48:00 +00:00
ParserString s_lparen("(");
ParserString s_rparen(")");
2011-11-05 23:31:19 +00:00
ParserString s_if("IF", true, true);
ParserString s_not("NOT", true, true);
ParserString s_exists("EXISTS", true, true);
ParserString s_as("AS", true, true);
ParserString s_select("SELECT", true, true);
ParserString s_view("VIEW", true, true);
ParserString s_materialized("MATERIALIZED", true, true);
ParserString s_populate("POPULATE", true, true);
2011-11-01 15:16:04 +00:00
ParserEngine engine_p;
2011-08-18 18:48:00 +00:00
ParserIdentifier name_p;
ParserColumnDeclarationList columns_p;
2011-08-18 18:48:00 +00:00
2011-10-30 05:19:41 +00:00
ASTPtr database;
ASTPtr table;
2011-08-18 18:48:00 +00:00
ASTPtr columns;
ASTPtr storage;
ASTPtr inner_storage;
2011-10-31 17:30:44 +00:00
ASTPtr as_database;
ASTPtr as_table;
2011-11-01 15:16:04 +00:00
ASTPtr select;
2011-08-18 18:48:00 +00:00
bool attach = false;
2011-08-19 18:31:14 +00:00
bool if_not_exists = false;
bool is_view = false;
bool is_materialized_view = false;
bool is_populate = false;
bool is_temporary = false;
2011-08-18 18:48:00 +00:00
ws.ignore(pos, end);
if (!s_create.ignore(pos, end, max_parsed_pos, expected))
2011-08-18 18:48:00 +00:00
{
if (s_attach.ignore(pos, end, max_parsed_pos, expected))
2011-08-18 18:48:00 +00:00
attach = true;
else
return false;
}
ws.ignore(pos, end);
if (s_temporary.ignore(pos, end, max_parsed_pos, expected))
{
is_temporary = true;
ws.ignore(pos, end);
}
if (s_database.ignore(pos, end, max_parsed_pos, expected))
2011-10-30 05:19:41 +00:00
{
ws.ignore(pos, end);
if (s_if.ignore(pos, end, max_parsed_pos, expected)
2011-11-05 23:31:19 +00:00
&& ws.ignore(pos, end)
&& s_not.ignore(pos, end, max_parsed_pos, expected)
2011-11-05 23:31:19 +00:00
&& ws.ignore(pos, end)
&& s_exists.ignore(pos, end, max_parsed_pos, expected)
2011-11-05 23:31:19 +00:00
&& ws.ignore(pos, end))
if_not_exists = true;
2011-08-18 18:48:00 +00:00
if (!name_p.parse(pos, end, database, max_parsed_pos, expected))
2011-11-05 23:31:19 +00:00
return false;
Squashed commit of the following: 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].
2016-03-19 01:18:49 +00:00
ws.ignore(pos, end);
engine_p.parse(pos, end, storage, max_parsed_pos, expected);
2011-11-05 23:31:19 +00:00
}
else if (s_table.ignore(pos, end, max_parsed_pos, expected))
2011-11-05 23:31:19 +00:00
{
2011-10-31 17:30:44 +00:00
ws.ignore(pos, end);
2011-08-18 18:48:00 +00:00
if (s_if.ignore(pos, end, max_parsed_pos, expected)
2011-11-05 23:31:19 +00:00
&& ws.ignore(pos, end)
&& s_not.ignore(pos, end, max_parsed_pos, expected)
2011-11-05 23:31:19 +00:00
&& ws.ignore(pos, end)
&& s_exists.ignore(pos, end, max_parsed_pos, expected)
2011-11-05 23:31:19 +00:00
&& ws.ignore(pos, end))
if_not_exists = true;
if (!name_p.parse(pos, end, table, max_parsed_pos, expected))
2011-10-31 17:30:44 +00:00
return false;
2011-08-18 18:48:00 +00:00
2011-10-31 17:30:44 +00:00
ws.ignore(pos, end);
2011-11-01 15:16:04 +00:00
if (s_dot.ignore(pos, end, max_parsed_pos, expected))
2011-11-05 23:31:19 +00:00
{
database = table;
if (!name_p.parse(pos, end, table, max_parsed_pos, expected))
2011-11-05 23:31:19 +00:00
return false;
2011-11-01 15:38:01 +00:00
2011-11-05 23:31:19 +00:00
ws.ignore(pos, end);
}
2011-08-18 18:48:00 +00:00
2011-11-05 23:31:19 +00:00
/// Список столбцов
if (s_lparen.ignore(pos, end, max_parsed_pos, expected))
2011-10-31 17:30:44 +00:00
{
2011-11-05 23:31:19 +00:00
ws.ignore(pos, end);
if (!columns_p.parse(pos, end, columns, max_parsed_pos, expected))
2011-11-05 23:31:19 +00:00
return false;
ws.ignore(pos, end);
if (!s_rparen.ignore(pos, end, max_parsed_pos, expected))
2011-11-05 23:31:19 +00:00
return false;
2011-11-05 23:31:19 +00:00
ws.ignore(pos, end);
if (!engine_p.parse(pos, end, storage, max_parsed_pos, expected))
2011-11-05 23:31:19 +00:00
return false;
/// Для engine VIEW необходимо так же считать запрос AS SELECT
if (storage && (typeid_cast<ASTFunction &>(*storage).name == "View"
|| typeid_cast<ASTFunction &>(*storage).name == "MaterializedView"))
{
if (!s_as.ignore(pos, end, max_parsed_pos, expected))
return false;
ws.ignore(pos, end);
Pos before_select = pos;
if (!s_select.ignore(pos, end, max_parsed_pos, expected))
return false;
pos = before_select;
ParserSelectQuery select_p;
select_p.parse(pos, end, select, max_parsed_pos, expected);
}
2011-11-01 15:16:04 +00:00
}
else
{
engine_p.parse(pos, end, storage, max_parsed_pos, expected);
2011-11-05 23:31:19 +00:00
if (!s_as.ignore(pos, end, max_parsed_pos, expected))
2011-10-31 17:30:44 +00:00
return false;
2011-08-18 18:48:00 +00:00
2011-10-31 17:30:44 +00:00
ws.ignore(pos, end);
2011-11-01 15:16:04 +00:00
2011-11-05 23:31:19 +00:00
/// AS SELECT ...
Pos before_select = pos;
if (s_select.ignore(pos, end, max_parsed_pos, expected))
2011-11-05 23:31:19 +00:00
{
pos = before_select;
ParserSelectQuery select_p;
select_p.parse(pos, end, select, max_parsed_pos, expected);
2011-11-05 23:31:19 +00:00
}
else
2011-11-01 15:16:04 +00:00
{
2011-11-05 23:31:19 +00:00
/// AS [db.]table
if (!name_p.parse(pos, end, as_table, max_parsed_pos, expected))
2011-11-01 15:16:04 +00:00
return false;
ws.ignore(pos, end);
2011-11-05 23:31:19 +00:00
if (s_dot.ignore(pos, end, max_parsed_pos, expected))
2011-11-05 23:31:19 +00:00
{
as_database = as_table;
if (!name_p.parse(pos, end, as_table, max_parsed_pos, expected))
2011-11-05 23:31:19 +00:00
return false;
ws.ignore(pos, end);
}
2012-07-12 20:06:45 +00:00
ws.ignore(pos, end);
/// Опционально - может быть указана ENGINE.
engine_p.parse(pos, end, storage, max_parsed_pos, expected);
2011-11-01 15:16:04 +00:00
}
2011-10-31 17:30:44 +00:00
}
2014-04-24 18:49:07 +00:00
}
else
{
/// VIEW or MATERIALIZED VIEW
if (s_materialized.ignore(pos, end, max_parsed_pos, expected) && ws.ignore(pos, end, max_parsed_pos, expected))
is_materialized_view = true;
else
is_view = true;
if (!s_view.ignore(pos, end, max_parsed_pos, expected) || !ws.ignore(pos, end, max_parsed_pos, expected))
return false;
if (s_if.ignore(pos, end, max_parsed_pos, expected)
&& ws.ignore(pos, end)
&& s_not.ignore(pos, end, max_parsed_pos, expected)
&& ws.ignore(pos, end)
&& s_exists.ignore(pos, end, max_parsed_pos, expected)
&& ws.ignore(pos, end))
if_not_exists = true;
if (!name_p.parse(pos, end, table, max_parsed_pos, expected))
return false;
ws.ignore(pos, end);
if (s_dot.ignore(pos, end, max_parsed_pos, expected))
{
database = table;
if (!name_p.parse(pos, end, table, max_parsed_pos, expected))
return false;
ws.ignore(pos, end);
}
2014-05-12 17:27:48 +00:00
/// Опционально - может быть указан список столбцов. Он должен полностью соответствовать SELECT-у.
if (s_lparen.ignore(pos, end, max_parsed_pos, expected))
2014-05-12 17:27:48 +00:00
{
ws.ignore(pos, end);
if (!columns_p.parse(pos, end, columns, max_parsed_pos, expected))
2014-05-12 17:27:48 +00:00
return false;
ws.ignore(pos, end);
if (!s_rparen.ignore(pos, end, max_parsed_pos, expected))
2014-05-12 17:27:48 +00:00
return false;
}
/// Опционально - может быть указана внутренняя ENGINE для MATERIALIZED VIEW
engine_p.parse(pos, end, inner_storage, max_parsed_pos, expected);
ws.ignore(pos, end);
if (s_populate.ignore(pos, end, max_parsed_pos, expected))
is_populate = true;
ws.ignore(pos, end);
/// AS SELECT ...
if (!s_as.ignore(pos, end, max_parsed_pos, expected))
return false;
ws.ignore(pos, end);
Pos before_select = pos;
if (!s_select.ignore(pos, end, max_parsed_pos, expected))
return false;
pos = before_select;
ParserSelectQuery select_p;
select_p.parse(pos, end, select, max_parsed_pos, expected);
2011-10-31 17:30:44 +00:00
}
2011-08-18 18:48:00 +00:00
2011-11-05 23:31:19 +00:00
ws.ignore(pos, end);
auto query = std::make_shared<ASTCreateQuery>(StringRange(begin, pos));
2011-08-18 18:48:00 +00:00
node = query;
query->attach = attach;
2011-08-19 18:31:14 +00:00
query->if_not_exists = if_not_exists;
query->is_view = is_view;
query->is_materialized_view = is_materialized_view;
query->is_populate = is_populate;
query->is_temporary = is_temporary;
2011-10-31 06:37:12 +00:00
if (database)
query->database = typeid_cast<ASTIdentifier &>(*database).name;
2011-11-05 23:31:19 +00:00
if (table)
query->table = typeid_cast<ASTIdentifier &>(*table).name;
if (inner_storage)
query->inner_storage = inner_storage;
2011-08-18 18:48:00 +00:00
query->columns = columns;
query->storage = storage;
2011-10-31 17:30:44 +00:00
if (as_database)
query->as_database = typeid_cast<ASTIdentifier &>(*as_database).name;
2011-10-31 17:30:44 +00:00
if (as_table)
query->as_table = typeid_cast<ASTIdentifier &>(*as_table).name;
2011-11-01 15:16:04 +00:00
query->select = select;
2011-08-18 18:48:00 +00:00
2012-12-27 17:40:54 +00:00
if (columns)
query->children.push_back(columns);
2011-11-01 15:16:04 +00:00
if (storage)
query->children.push_back(storage);
if (select)
query->children.push_back(select);
if (inner_storage)
query->children.push_back(inner_storage);
2011-08-18 18:48:00 +00:00
return true;
}
}