2019-01-14 18:15:04 +00:00
|
|
|
#include <Common/typeid_cast.h>
|
2023-12-27 17:13:16 +00:00
|
|
|
#include <Parsers/ParserStringAndSubstitution.h>
|
2017-04-01 09:19:00 +00:00
|
|
|
#include <Parsers/ParserAlterQuery.h>
|
|
|
|
#include <Parsers/CommonParsers.h>
|
|
|
|
#include <Parsers/ExpressionElementParsers.h>
|
2018-08-07 13:58:11 +00:00
|
|
|
#include <Parsers/ExpressionListParsers.h>
|
2017-04-01 09:19:00 +00:00
|
|
|
#include <Parsers/ParserCreateQuery.h>
|
2017-09-06 20:34:26 +00:00
|
|
|
#include <Parsers/ParserPartition.h>
|
2023-11-29 02:32:41 +00:00
|
|
|
#include <Parsers/ParserRefreshStrategy.h>
|
2020-01-29 17:44:16 +00:00
|
|
|
#include <Parsers/ParserSelectWithUnionQuery.h>
|
2019-07-24 15:22:16 +00:00
|
|
|
#include <Parsers/ParserSetQuery.h>
|
2017-04-01 09:19:00 +00:00
|
|
|
#include <Parsers/ASTIdentifier.h>
|
2019-02-05 14:50:25 +00:00
|
|
|
#include <Parsers/ASTIndexDeclaration.h>
|
2017-04-01 09:19:00 +00:00
|
|
|
#include <Parsers/ASTAlterQuery.h>
|
|
|
|
#include <Parsers/ASTLiteral.h>
|
2018-05-21 13:49:54 +00:00
|
|
|
#include <Parsers/parseDatabaseAndTableName.h>
|
|
|
|
|
2013-08-07 13:07:42 +00:00
|
|
|
|
|
|
|
namespace DB
|
|
|
|
{
|
2016-01-28 01:00:27 +00:00
|
|
|
|
2018-06-09 15:53:14 +00:00
|
|
|
bool ParserAlterCommand::parseImpl(Pos & pos, ASTPtr & node, Expected & expected)
|
2013-08-07 13:07:42 +00:00
|
|
|
{
|
2018-06-09 15:53:14 +00:00
|
|
|
auto command = std::make_shared<ASTAlterCommand>();
|
|
|
|
node = command;
|
|
|
|
|
2017-06-18 03:07:03 +00:00
|
|
|
ParserKeyword s_add_column("ADD COLUMN");
|
|
|
|
ParserKeyword s_drop_column("DROP COLUMN");
|
2017-06-22 11:01:30 +00:00
|
|
|
ParserKeyword s_clear_column("CLEAR COLUMN");
|
2017-06-18 03:07:03 +00:00
|
|
|
ParserKeyword s_modify_column("MODIFY COLUMN");
|
2021-11-30 13:07:14 +00:00
|
|
|
ParserKeyword s_alter_column("ALTER COLUMN");
|
2020-03-25 18:44:08 +00:00
|
|
|
ParserKeyword s_rename_column("RENAME COLUMN");
|
2018-10-14 15:30:06 +00:00
|
|
|
ParserKeyword s_comment_column("COMMENT COLUMN");
|
2021-07-31 18:17:06 +00:00
|
|
|
ParserKeyword s_materialize_column("MATERIALIZE COLUMN");
|
|
|
|
|
2018-10-15 18:47:47 +00:00
|
|
|
ParserKeyword s_modify_order_by("MODIFY ORDER BY");
|
2020-08-27 13:10:10 +00:00
|
|
|
ParserKeyword s_modify_sample_by("MODIFY SAMPLE BY");
|
2019-04-15 09:30:45 +00:00
|
|
|
ParserKeyword s_modify_ttl("MODIFY TTL");
|
2020-01-22 13:24:20 +00:00
|
|
|
ParserKeyword s_materialize_ttl("MATERIALIZE TTL");
|
2019-07-24 15:22:16 +00:00
|
|
|
ParserKeyword s_modify_setting("MODIFY SETTING");
|
2020-12-02 21:18:25 +00:00
|
|
|
ParserKeyword s_reset_setting("RESET SETTING");
|
2020-01-29 17:44:16 +00:00
|
|
|
ParserKeyword s_modify_query("MODIFY QUERY");
|
2024-02-22 16:47:50 +00:00
|
|
|
ParserKeyword s_modify_sql_security("MODIFY SQL SECURITY");
|
2023-11-29 02:32:41 +00:00
|
|
|
ParserKeyword s_modify_refresh("MODIFY REFRESH");
|
2017-06-18 03:07:03 +00:00
|
|
|
|
2019-02-05 14:50:25 +00:00
|
|
|
ParserKeyword s_add_index("ADD INDEX");
|
|
|
|
ParserKeyword s_drop_index("DROP INDEX");
|
2019-05-09 14:25:18 +00:00
|
|
|
ParserKeyword s_clear_index("CLEAR INDEX");
|
2019-04-09 15:36:33 +00:00
|
|
|
ParserKeyword s_materialize_index("MATERIALIZE INDEX");
|
2019-02-05 14:50:25 +00:00
|
|
|
|
2023-08-09 20:57:49 +00:00
|
|
|
ParserKeyword s_add_statistic("ADD STATISTIC");
|
|
|
|
ParserKeyword s_drop_statistic("DROP STATISTIC");
|
|
|
|
ParserKeyword s_clear_statistic("CLEAR STATISTIC");
|
|
|
|
ParserKeyword s_materialize_statistic("MATERIALIZE STATISTIC");
|
|
|
|
|
2019-06-02 14:41:12 +00:00
|
|
|
ParserKeyword s_add_constraint("ADD CONSTRAINT");
|
|
|
|
ParserKeyword s_drop_constraint("DROP CONSTRAINT");
|
|
|
|
|
2021-02-10 14:12:49 +00:00
|
|
|
ParserKeyword s_add_projection("ADD PROJECTION");
|
|
|
|
ParserKeyword s_drop_projection("DROP PROJECTION");
|
|
|
|
ParserKeyword s_clear_projection("CLEAR PROJECTION");
|
|
|
|
ParserKeyword s_materialize_projection("MATERIALIZE PROJECTION");
|
2021-09-20 11:06:19 +00:00
|
|
|
ParserKeyword s_modify_comment("MODIFY COMMENT");
|
2021-02-10 14:12:49 +00:00
|
|
|
|
2019-05-28 21:17:48 +00:00
|
|
|
ParserKeyword s_add("ADD");
|
|
|
|
ParserKeyword s_drop("DROP");
|
|
|
|
ParserKeyword s_suspend("SUSPEND");
|
|
|
|
ParserKeyword s_resume("RESUME");
|
|
|
|
ParserKeyword s_refresh("REFRESH");
|
|
|
|
ParserKeyword s_modify("MODIFY");
|
2019-02-05 14:50:25 +00:00
|
|
|
|
2017-06-18 03:07:03 +00:00
|
|
|
ParserKeyword s_attach_partition("ATTACH PARTITION");
|
2020-09-04 15:48:51 +00:00
|
|
|
ParserKeyword s_attach_part("ATTACH PART");
|
2017-06-18 03:07:03 +00:00
|
|
|
ParserKeyword s_detach_partition("DETACH PARTITION");
|
2020-09-04 15:48:51 +00:00
|
|
|
ParserKeyword s_detach_part("DETACH PART");
|
2017-06-18 03:07:03 +00:00
|
|
|
ParserKeyword s_drop_partition("DROP PARTITION");
|
2020-09-04 15:48:51 +00:00
|
|
|
ParserKeyword s_drop_part("DROP PART");
|
2019-08-20 09:59:19 +00:00
|
|
|
ParserKeyword s_move_partition("MOVE PARTITION");
|
2020-09-04 15:48:51 +00:00
|
|
|
ParserKeyword s_move_part("MOVE PART");
|
2019-07-22 11:23:11 +00:00
|
|
|
ParserKeyword s_drop_detached_partition("DROP DETACHED PARTITION");
|
|
|
|
ParserKeyword s_drop_detached_part("DROP DETACHED PART");
|
2017-06-18 03:07:03 +00:00
|
|
|
ParserKeyword s_fetch_partition("FETCH PARTITION");
|
2021-04-13 04:40:33 +00:00
|
|
|
ParserKeyword s_fetch_part("FETCH PART");
|
2018-10-30 15:04:13 +00:00
|
|
|
ParserKeyword s_replace_partition("REPLACE PARTITION");
|
|
|
|
ParserKeyword s_freeze("FREEZE");
|
2021-02-24 14:26:46 +00:00
|
|
|
ParserKeyword s_unfreeze("UNFREEZE");
|
2017-06-18 03:07:03 +00:00
|
|
|
ParserKeyword s_partition("PARTITION");
|
|
|
|
|
2020-07-01 14:58:52 +00:00
|
|
|
ParserKeyword s_first("FIRST");
|
2017-06-18 03:07:03 +00:00
|
|
|
ParserKeyword s_after("AFTER");
|
2018-12-21 14:53:00 +00:00
|
|
|
ParserKeyword s_if_not_exists("IF NOT EXISTS");
|
|
|
|
ParserKeyword s_if_exists("IF EXISTS");
|
2017-06-18 03:07:03 +00:00
|
|
|
ParserKeyword s_from("FROM");
|
2017-06-22 11:01:30 +00:00
|
|
|
ParserKeyword s_in_partition("IN PARTITION");
|
2017-06-18 03:07:03 +00:00
|
|
|
ParserKeyword s_with("WITH");
|
|
|
|
ParserKeyword s_name("NAME");
|
2017-04-01 07:20:54 +00:00
|
|
|
|
2019-07-18 15:19:03 +00:00
|
|
|
ParserKeyword s_to_disk("TO DISK");
|
|
|
|
ParserKeyword s_to_volume("TO VOLUME");
|
2019-09-17 11:59:09 +00:00
|
|
|
ParserKeyword s_to_table("TO TABLE");
|
2020-11-24 14:24:48 +00:00
|
|
|
ParserKeyword s_to_shard("TO SHARD");
|
2019-07-18 15:19:03 +00:00
|
|
|
|
2020-11-10 10:23:46 +00:00
|
|
|
ParserKeyword s_delete("DELETE");
|
2018-08-07 13:58:11 +00:00
|
|
|
ParserKeyword s_update("UPDATE");
|
|
|
|
ParserKeyword s_where("WHERE");
|
2020-03-25 18:44:08 +00:00
|
|
|
ParserKeyword s_to("TO");
|
2018-02-02 16:02:43 +00:00
|
|
|
|
2020-09-20 13:27:33 +00:00
|
|
|
ParserKeyword s_remove("REMOVE");
|
|
|
|
ParserKeyword s_default("DEFAULT");
|
|
|
|
ParserKeyword s_materialized("MATERIALIZED");
|
|
|
|
ParserKeyword s_alias("ALIAS");
|
|
|
|
ParserKeyword s_comment("COMMENT");
|
|
|
|
ParserKeyword s_codec("CODEC");
|
|
|
|
ParserKeyword s_ttl("TTL");
|
2024-01-18 05:17:07 +00:00
|
|
|
ParserKeyword s_settings("SETTINGS");
|
2020-09-20 13:27:33 +00:00
|
|
|
|
|
|
|
ParserKeyword s_remove_ttl("REMOVE TTL");
|
2021-10-14 13:44:28 +00:00
|
|
|
ParserKeyword s_remove_sample_by("REMOVE SAMPLE BY");
|
2023-12-01 19:12:05 +00:00
|
|
|
ParserKeyword s_apply_deleted_mask("APPLY DELETED MASK");
|
2020-09-20 13:27:33 +00:00
|
|
|
|
2017-04-01 07:20:54 +00:00
|
|
|
ParserCompoundIdentifier parser_name;
|
2018-06-09 15:53:14 +00:00
|
|
|
ParserStringLiteral parser_string_literal;
|
2023-12-27 17:13:16 +00:00
|
|
|
ParserStringAndSubstitution parser_string_and_substituion;
|
2020-09-20 13:27:33 +00:00
|
|
|
ParserIdentifier parser_remove_property;
|
2017-04-01 07:20:54 +00:00
|
|
|
ParserCompoundColumnDeclaration parser_col_decl;
|
2019-02-05 14:50:25 +00:00
|
|
|
ParserIndexDeclaration parser_idx_decl;
|
2023-08-09 20:57:49 +00:00
|
|
|
ParserStatisticDeclaration parser_stat_decl;
|
2019-06-02 14:41:12 +00:00
|
|
|
ParserConstraintDeclaration parser_constraint_decl;
|
2021-02-10 14:12:49 +00:00
|
|
|
ParserProjectionDeclaration parser_projection_decl;
|
2020-09-20 13:27:33 +00:00
|
|
|
ParserCompoundColumnDeclaration parser_modify_col_decl(false, false, true);
|
2017-09-06 20:34:26 +00:00
|
|
|
ParserPartition parser_partition;
|
2018-08-07 13:58:11 +00:00
|
|
|
ParserExpression parser_exp_elem;
|
|
|
|
ParserList parser_assignment_list(
|
|
|
|
std::make_unique<ParserAssignment>(), std::make_unique<ParserToken>(TokenType::Comma),
|
|
|
|
/* allow_empty = */ false);
|
2019-07-24 15:22:16 +00:00
|
|
|
ParserSetQuery parser_settings(true);
|
2020-12-02 21:18:25 +00:00
|
|
|
ParserList parser_reset_setting(
|
|
|
|
std::make_unique<ParserIdentifier>(), std::make_unique<ParserToken>(TokenType::Comma),
|
|
|
|
/* allow_empty = */ false);
|
2019-05-28 21:17:48 +00:00
|
|
|
ParserNameList values_p;
|
2020-01-29 17:44:16 +00:00
|
|
|
ParserSelectWithUnionQuery select_p;
|
2024-02-22 16:47:50 +00:00
|
|
|
ParserSQLSecurity sql_security_p;
|
2023-11-29 02:32:41 +00:00
|
|
|
ParserRefreshStrategy refresh_p;
|
2019-10-09 13:02:05 +00:00
|
|
|
ParserTTLExpressionList parser_ttl_list;
|
2017-04-01 07:20:54 +00:00
|
|
|
|
2023-12-27 17:13:16 +00:00
|
|
|
ASTPtr command_col_decl;
|
|
|
|
ASTPtr command_column;
|
|
|
|
ASTPtr command_order_by;
|
|
|
|
ASTPtr command_sample_by;
|
|
|
|
ASTPtr command_index_decl;
|
|
|
|
ASTPtr command_index;
|
|
|
|
ASTPtr command_constraint_decl;
|
|
|
|
ASTPtr command_constraint;
|
|
|
|
ASTPtr command_projection_decl;
|
|
|
|
ASTPtr command_projection;
|
|
|
|
ASTPtr command_statistic_decl;
|
|
|
|
ASTPtr command_partition;
|
|
|
|
ASTPtr command_predicate;
|
|
|
|
ASTPtr command_update_assignments;
|
|
|
|
ASTPtr command_comment;
|
|
|
|
ASTPtr command_ttl;
|
|
|
|
ASTPtr command_settings_changes;
|
|
|
|
ASTPtr command_settings_resets;
|
|
|
|
ASTPtr command_select;
|
|
|
|
ASTPtr command_values;
|
|
|
|
ASTPtr command_rename_to;
|
2024-02-22 16:47:50 +00:00
|
|
|
ASTPtr command_sql_security;
|
2023-12-27 17:13:16 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
switch (alter_object)
|
2018-06-09 15:53:14 +00:00
|
|
|
{
|
2021-08-20 17:59:57 +00:00
|
|
|
case ASTAlterQuery::AlterObjectType::LIVE_VIEW:
|
2018-06-09 15:53:14 +00:00
|
|
|
{
|
2021-08-20 17:59:57 +00:00
|
|
|
if (s_refresh.ignore(pos, expected))
|
2019-05-28 21:17:48 +00:00
|
|
|
{
|
2021-08-20 17:59:57 +00:00
|
|
|
command->type = ASTAlterCommand::LIVE_VIEW_REFRESH;
|
2019-05-28 21:17:48 +00:00
|
|
|
}
|
2021-08-20 17:59:57 +00:00
|
|
|
else
|
2020-03-25 18:44:08 +00:00
|
|
|
return false;
|
2021-08-20 17:59:57 +00:00
|
|
|
break;
|
2020-03-25 18:44:08 +00:00
|
|
|
}
|
2021-08-20 17:59:57 +00:00
|
|
|
case ASTAlterQuery::AlterObjectType::DATABASE:
|
2021-07-31 18:17:06 +00:00
|
|
|
{
|
2021-08-20 17:59:57 +00:00
|
|
|
if (s_modify_setting.ignore(pos, expected))
|
2021-07-31 18:17:06 +00:00
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_settings.parse(pos, command_settings_changes, expected))
|
2021-07-31 18:17:06 +00:00
|
|
|
return false;
|
2021-08-27 06:30:21 +00:00
|
|
|
command->type = ASTAlterCommand::MODIFY_DATABASE_SETTING;
|
2021-07-31 18:17:06 +00:00
|
|
|
}
|
2021-08-20 17:59:57 +00:00
|
|
|
else
|
2019-05-09 14:25:18 +00:00
|
|
|
return false;
|
2021-08-20 17:59:57 +00:00
|
|
|
break;
|
2019-05-09 14:25:18 +00:00
|
|
|
}
|
2021-08-27 06:30:21 +00:00
|
|
|
default:
|
|
|
|
break;
|
2021-08-20 17:59:57 +00:00
|
|
|
case ASTAlterQuery::AlterObjectType::TABLE:
|
2020-09-04 15:48:51 +00:00
|
|
|
{
|
2022-06-17 07:46:44 +00:00
|
|
|
if (s_add_column.ignore(pos, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
{
|
|
|
|
if (s_if_not_exists.ignore(pos, expected))
|
|
|
|
command->if_not_exists = true;
|
2020-09-04 15:48:51 +00:00
|
|
|
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_col_decl.parse(pos, command_col_decl, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
2019-08-22 20:38:58 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
if (s_first.ignore(pos, expected))
|
|
|
|
command->first = true;
|
|
|
|
else if (s_after.ignore(pos, expected))
|
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_name.parse(pos, command_column, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
|
|
|
}
|
2019-02-05 14:50:25 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
command->type = ASTAlterCommand::ADD_COLUMN;
|
|
|
|
}
|
|
|
|
else if (s_rename_column.ignore(pos, expected))
|
|
|
|
{
|
|
|
|
if (s_if_exists.ignore(pos, expected))
|
|
|
|
command->if_exists = true;
|
2019-02-05 14:50:25 +00:00
|
|
|
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_name.parse(pos, command_column, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
2019-02-05 14:50:25 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
if (!s_to.ignore(pos, expected))
|
|
|
|
return false;
|
2018-12-21 14:53:00 +00:00
|
|
|
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_name.parse(pos, command_rename_to, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
2018-12-21 14:53:00 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
command->type = ASTAlterCommand::RENAME_COLUMN;
|
|
|
|
}
|
2021-09-04 22:59:44 +00:00
|
|
|
else if (s_materialize_column.ignore(pos, expected))
|
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_name.parse(pos, command_column, expected))
|
2021-09-04 22:59:44 +00:00
|
|
|
return false;
|
2017-04-01 07:20:54 +00:00
|
|
|
|
2021-09-04 22:59:44 +00:00
|
|
|
command->type = ASTAlterCommand::MATERIALIZE_COLUMN;
|
|
|
|
command->detach = false;
|
2018-06-09 15:53:14 +00:00
|
|
|
|
2021-09-04 22:59:44 +00:00
|
|
|
if (s_in_partition.ignore(pos, expected))
|
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_partition.parse(pos, command_partition, expected))
|
2021-09-04 22:59:44 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
2021-08-20 17:59:57 +00:00
|
|
|
else if (s_drop_partition.ignore(pos, expected))
|
2019-08-16 10:55:40 +00:00
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_partition.parse(pos, command_partition, expected))
|
2019-08-16 10:55:40 +00:00
|
|
|
return false;
|
2017-04-01 07:20:54 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
command->type = ASTAlterCommand::DROP_PARTITION;
|
2019-08-16 10:55:40 +00:00
|
|
|
}
|
2021-08-20 17:59:57 +00:00
|
|
|
else if (s_drop_part.ignore(pos, expected))
|
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_string_and_substituion.parse(pos, command_partition, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
2019-02-05 14:50:25 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
command->type = ASTAlterCommand::DROP_PARTITION;
|
|
|
|
command->part = true;
|
|
|
|
}
|
|
|
|
else if (s_drop_detached_partition.ignore(pos, expected))
|
2019-08-16 10:55:40 +00:00
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_partition.parse(pos, command_partition, expected))
|
2019-08-16 10:55:40 +00:00
|
|
|
return false;
|
2017-04-01 07:20:54 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
command->type = ASTAlterCommand::DROP_DETACHED_PARTITION;
|
|
|
|
}
|
|
|
|
else if (s_drop_detached_part.ignore(pos, expected))
|
2019-05-28 21:17:48 +00:00
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_string_and_substituion.parse(pos, command_partition, expected))
|
2019-05-28 21:17:48 +00:00
|
|
|
return false;
|
2017-04-01 07:20:54 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
command->type = ASTAlterCommand::DROP_DETACHED_PARTITION;
|
|
|
|
command->part = true;
|
2019-05-28 21:17:48 +00:00
|
|
|
}
|
2021-08-20 17:59:57 +00:00
|
|
|
else if (s_drop_column.ignore(pos, expected))
|
2019-05-28 21:17:48 +00:00
|
|
|
{
|
2021-08-20 17:59:57 +00:00
|
|
|
if (s_if_exists.ignore(pos, expected))
|
|
|
|
command->if_exists = true;
|
2017-04-01 07:20:54 +00:00
|
|
|
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_name.parse(pos, command_column, expected))
|
2019-05-28 21:17:48 +00:00
|
|
|
return false;
|
2019-04-09 15:36:33 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
command->type = ASTAlterCommand::DROP_COLUMN;
|
|
|
|
command->detach = false;
|
2019-05-28 21:17:48 +00:00
|
|
|
}
|
2021-08-20 17:59:57 +00:00
|
|
|
else if (s_clear_column.ignore(pos, expected))
|
|
|
|
{
|
|
|
|
if (s_if_exists.ignore(pos, expected))
|
|
|
|
command->if_exists = true;
|
2017-04-01 07:20:54 +00:00
|
|
|
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_name.parse(pos, command_column, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
2017-04-01 07:20:54 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
command->type = ASTAlterCommand::DROP_COLUMN;
|
|
|
|
command->clear_column = true;
|
|
|
|
command->detach = false;
|
2017-04-01 07:20:54 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
if (s_in_partition.ignore(pos, expected))
|
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_partition.parse(pos, command_partition, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (s_add_index.ignore(pos, expected))
|
|
|
|
{
|
|
|
|
if (s_if_not_exists.ignore(pos, expected))
|
|
|
|
command->if_not_exists = true;
|
2018-06-09 15:53:14 +00:00
|
|
|
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_idx_decl.parse(pos, command_index_decl, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
2017-04-01 07:20:54 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
if (s_first.ignore(pos, expected))
|
|
|
|
command->first = true;
|
|
|
|
else if (s_after.ignore(pos, expected))
|
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_name.parse(pos, command_index, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
|
|
|
}
|
2017-04-01 07:20:54 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
command->type = ASTAlterCommand::ADD_INDEX;
|
|
|
|
}
|
|
|
|
else if (s_drop_index.ignore(pos, expected))
|
2021-02-10 14:12:49 +00:00
|
|
|
{
|
2021-08-20 17:59:57 +00:00
|
|
|
if (s_if_exists.ignore(pos, expected))
|
|
|
|
command->if_exists = true;
|
|
|
|
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_name.parse(pos, command_index, expected))
|
2021-02-10 14:12:49 +00:00
|
|
|
return false;
|
2021-08-20 17:59:57 +00:00
|
|
|
|
|
|
|
command->type = ASTAlterCommand::DROP_INDEX;
|
|
|
|
command->detach = false;
|
2021-02-10 14:12:49 +00:00
|
|
|
}
|
2021-08-20 17:59:57 +00:00
|
|
|
else if (s_clear_index.ignore(pos, expected))
|
|
|
|
{
|
|
|
|
if (s_if_exists.ignore(pos, expected))
|
|
|
|
command->if_exists = true;
|
2017-06-22 11:01:30 +00:00
|
|
|
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_name.parse(pos, command_index, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
2017-06-22 11:01:30 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
command->type = ASTAlterCommand::DROP_INDEX;
|
|
|
|
command->clear_index = true;
|
|
|
|
command->detach = false;
|
2017-04-01 07:20:54 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
if (s_in_partition.ignore(pos, expected))
|
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_partition.parse(pos, command_partition, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (s_materialize_index.ignore(pos, expected))
|
2019-05-28 21:17:48 +00:00
|
|
|
{
|
2021-08-20 17:59:57 +00:00
|
|
|
if (s_if_exists.ignore(pos, expected))
|
|
|
|
command->if_exists = true;
|
|
|
|
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_name.parse(pos, command_index, expected))
|
2019-05-28 21:17:48 +00:00
|
|
|
return false;
|
2021-08-20 17:59:57 +00:00
|
|
|
|
|
|
|
command->type = ASTAlterCommand::MATERIALIZE_INDEX;
|
|
|
|
command->detach = false;
|
|
|
|
|
|
|
|
if (s_in_partition.ignore(pos, expected))
|
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_partition.parse(pos, command_partition, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
|
|
|
}
|
2019-05-28 21:17:48 +00:00
|
|
|
}
|
2023-08-09 20:57:49 +00:00
|
|
|
else if (s_add_statistic.ignore(pos, expected))
|
|
|
|
{
|
|
|
|
if (s_if_not_exists.ignore(pos, expected))
|
|
|
|
command->if_not_exists = true;
|
|
|
|
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_stat_decl.parse(pos, command_statistic_decl, expected))
|
2023-08-09 20:57:49 +00:00
|
|
|
return false;
|
|
|
|
|
|
|
|
command->type = ASTAlterCommand::ADD_STATISTIC;
|
|
|
|
}
|
|
|
|
else if (s_drop_statistic.ignore(pos, expected))
|
|
|
|
{
|
|
|
|
if (s_if_exists.ignore(pos, expected))
|
|
|
|
command->if_exists = true;
|
|
|
|
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_stat_decl.parse(pos, command_statistic_decl, expected))
|
2023-08-09 20:57:49 +00:00
|
|
|
return false;
|
|
|
|
|
|
|
|
command->type = ASTAlterCommand::DROP_STATISTIC;
|
|
|
|
}
|
|
|
|
else if (s_clear_statistic.ignore(pos, expected))
|
|
|
|
{
|
|
|
|
if (s_if_exists.ignore(pos, expected))
|
|
|
|
command->if_exists = true;
|
|
|
|
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_stat_decl.parse(pos, command_statistic_decl, expected))
|
2023-08-09 20:57:49 +00:00
|
|
|
return false;
|
|
|
|
|
|
|
|
command->type = ASTAlterCommand::DROP_STATISTIC;
|
|
|
|
command->clear_statistic = true;
|
|
|
|
command->detach = false;
|
|
|
|
|
|
|
|
if (s_in_partition.ignore(pos, expected))
|
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_partition.parse(pos, command_partition, expected))
|
2023-08-09 20:57:49 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (s_materialize_statistic.ignore(pos, expected))
|
|
|
|
{
|
|
|
|
if (s_if_exists.ignore(pos, expected))
|
|
|
|
command->if_exists = true;
|
|
|
|
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_stat_decl.parse(pos, command_statistic_decl, expected))
|
2023-08-09 20:57:49 +00:00
|
|
|
return false;
|
|
|
|
|
|
|
|
command->type = ASTAlterCommand::MATERIALIZE_STATISTIC;
|
|
|
|
command->detach = false;
|
2021-08-20 17:59:57 +00:00
|
|
|
|
|
|
|
if (s_in_partition.ignore(pos, expected))
|
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_partition.parse(pos, command_partition, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
|
|
|
}
|
2019-05-28 21:17:48 +00:00
|
|
|
}
|
2021-08-20 17:59:57 +00:00
|
|
|
else if (s_add_projection.ignore(pos, expected))
|
|
|
|
{
|
|
|
|
if (s_if_not_exists.ignore(pos, expected))
|
|
|
|
command->if_not_exists = true;
|
2021-02-10 14:12:49 +00:00
|
|
|
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_projection_decl.parse(pos, command_projection_decl, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
2021-02-10 14:12:49 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
if (s_first.ignore(pos, expected))
|
|
|
|
command->first = true;
|
|
|
|
else if (s_after.ignore(pos, expected))
|
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_name.parse(pos, command_projection, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
command->type = ASTAlterCommand::ADD_PROJECTION;
|
|
|
|
}
|
|
|
|
else if (s_drop_projection.ignore(pos, expected))
|
2021-02-10 14:12:49 +00:00
|
|
|
{
|
2021-08-20 17:59:57 +00:00
|
|
|
if (s_if_exists.ignore(pos, expected))
|
|
|
|
command->if_exists = true;
|
|
|
|
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_name.parse(pos, command_projection, expected))
|
2021-02-10 14:12:49 +00:00
|
|
|
return false;
|
2021-08-20 17:59:57 +00:00
|
|
|
|
|
|
|
command->type = ASTAlterCommand::DROP_PROJECTION;
|
|
|
|
command->detach = false;
|
2021-02-10 14:12:49 +00:00
|
|
|
}
|
2021-08-20 17:59:57 +00:00
|
|
|
else if (s_clear_projection.ignore(pos, expected))
|
|
|
|
{
|
|
|
|
if (s_if_exists.ignore(pos, expected))
|
|
|
|
command->if_exists = true;
|
2021-02-10 14:12:49 +00:00
|
|
|
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_name.parse(pos, command_projection, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
2021-02-10 14:12:49 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
command->type = ASTAlterCommand::DROP_PROJECTION;
|
|
|
|
command->clear_projection = true;
|
|
|
|
command->detach = false;
|
2021-02-10 14:12:49 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
if (s_in_partition.ignore(pos, expected))
|
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_partition.parse(pos, command_partition, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (s_materialize_projection.ignore(pos, expected))
|
|
|
|
{
|
|
|
|
if (s_if_exists.ignore(pos, expected))
|
|
|
|
command->if_exists = true;
|
2021-02-10 14:12:49 +00:00
|
|
|
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_name.parse(pos, command_projection, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
2021-02-10 14:12:49 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
command->type = ASTAlterCommand::MATERIALIZE_PROJECTION;
|
|
|
|
command->detach = false;
|
2021-02-10 14:12:49 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
if (s_in_partition.ignore(pos, expected))
|
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_partition.parse(pos, command_partition, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (s_move_part.ignore(pos, expected))
|
2021-02-10 14:12:49 +00:00
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_string_and_substituion.parse(pos, command_partition, expected))
|
2021-02-10 14:12:49 +00:00
|
|
|
return false;
|
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
command->type = ASTAlterCommand::MOVE_PARTITION;
|
|
|
|
command->part = true;
|
2021-02-10 14:12:49 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
if (s_to_disk.ignore(pos))
|
|
|
|
command->move_destination_type = DataDestinationType::DISK;
|
|
|
|
else if (s_to_volume.ignore(pos))
|
|
|
|
command->move_destination_type = DataDestinationType::VOLUME;
|
|
|
|
else if (s_to_shard.ignore(pos))
|
|
|
|
{
|
|
|
|
command->move_destination_type = DataDestinationType::SHARD;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
return false;
|
|
|
|
|
2023-02-13 15:10:16 +00:00
|
|
|
ASTPtr ast_space_name;
|
|
|
|
if (!parser_string_literal.parse(pos, ast_space_name, expected))
|
|
|
|
return false;
|
2021-02-10 14:12:49 +00:00
|
|
|
|
2023-02-13 15:10:16 +00:00
|
|
|
command->move_destination_name = ast_space_name->as<ASTLiteral &>().value.get<const String &>();
|
2021-08-20 17:59:57 +00:00
|
|
|
}
|
|
|
|
else if (s_move_partition.ignore(pos, expected))
|
2021-02-10 14:12:49 +00:00
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_partition.parse(pos, command_partition, expected))
|
2019-05-28 21:17:48 +00:00
|
|
|
return false;
|
2019-07-26 08:42:17 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
command->type = ASTAlterCommand::MOVE_PARTITION;
|
2019-08-20 09:59:19 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
if (s_to_disk.ignore(pos))
|
|
|
|
command->move_destination_type = DataDestinationType::DISK;
|
|
|
|
else if (s_to_volume.ignore(pos))
|
|
|
|
command->move_destination_type = DataDestinationType::VOLUME;
|
|
|
|
else if (s_to_table.ignore(pos))
|
|
|
|
{
|
|
|
|
if (!parseDatabaseAndTableName(pos, expected, command->to_database, command->to_table))
|
|
|
|
return false;
|
|
|
|
command->move_destination_type = DataDestinationType::TABLE;
|
|
|
|
}
|
|
|
|
else
|
2019-09-17 11:59:09 +00:00
|
|
|
return false;
|
2021-08-20 17:59:57 +00:00
|
|
|
|
|
|
|
if (command->move_destination_type != DataDestinationType::TABLE)
|
|
|
|
{
|
|
|
|
ASTPtr ast_space_name;
|
|
|
|
if (!parser_string_literal.parse(pos, ast_space_name, expected))
|
|
|
|
return false;
|
|
|
|
|
|
|
|
command->move_destination_name = ast_space_name->as<ASTLiteral &>().value.get<const String &>();
|
|
|
|
}
|
2019-09-17 11:59:09 +00:00
|
|
|
}
|
2021-08-20 17:59:57 +00:00
|
|
|
else if (s_add_constraint.ignore(pos, expected))
|
2020-11-24 14:24:48 +00:00
|
|
|
{
|
2021-08-20 17:59:57 +00:00
|
|
|
if (s_if_not_exists.ignore(pos, expected))
|
|
|
|
command->if_not_exists = true;
|
2019-07-26 08:42:17 +00:00
|
|
|
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_constraint_decl.parse(pos, command_constraint_decl, expected))
|
2019-09-16 07:27:38 +00:00
|
|
|
return false;
|
2019-07-18 15:19:03 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
command->type = ASTAlterCommand::ADD_CONSTRAINT;
|
2019-09-16 07:27:38 +00:00
|
|
|
}
|
2021-08-20 17:59:57 +00:00
|
|
|
else if (s_drop_constraint.ignore(pos, expected))
|
|
|
|
{
|
|
|
|
if (s_if_exists.ignore(pos, expected))
|
|
|
|
command->if_exists = true;
|
2019-07-18 15:19:03 +00:00
|
|
|
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_name.parse(pos, command_constraint, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
2019-07-18 15:19:03 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
command->type = ASTAlterCommand::DROP_CONSTRAINT;
|
|
|
|
command->detach = false;
|
|
|
|
}
|
|
|
|
else if (s_detach_partition.ignore(pos, expected))
|
2019-09-16 07:27:38 +00:00
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_partition.parse(pos, command_partition, expected))
|
2019-09-17 11:59:09 +00:00
|
|
|
return false;
|
2018-05-21 13:49:54 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
command->type = ASTAlterCommand::DROP_PARTITION;
|
|
|
|
command->detach = true;
|
|
|
|
}
|
|
|
|
else if (s_detach_part.ignore(pos, expected))
|
2019-09-16 07:27:38 +00:00
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_string_and_substituion.parse(pos, command_partition, expected))
|
2019-09-16 07:27:38 +00:00
|
|
|
return false;
|
2018-05-21 13:49:54 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
command->type = ASTAlterCommand::DROP_PARTITION;
|
|
|
|
command->part = true;
|
|
|
|
command->detach = true;
|
2019-09-16 07:27:38 +00:00
|
|
|
}
|
2021-08-20 17:59:57 +00:00
|
|
|
else if (s_attach_partition.ignore(pos, expected))
|
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_partition.parse(pos, command_partition, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
2018-05-21 13:49:54 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
if (s_from.ignore(pos))
|
|
|
|
{
|
|
|
|
if (!parseDatabaseAndTableName(pos, expected, command->from_database, command->from_table))
|
|
|
|
return false;
|
2018-05-21 13:49:54 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
command->replace = false;
|
|
|
|
command->type = ASTAlterCommand::REPLACE_PARTITION;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
command->type = ASTAlterCommand::ATTACH_PARTITION;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (s_replace_partition.ignore(pos, expected))
|
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_partition.parse(pos, command_partition, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
2020-09-04 15:48:51 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
if (!s_from.ignore(pos, expected))
|
|
|
|
return false;
|
2014-10-09 20:28:33 +00:00
|
|
|
|
2019-05-28 21:17:48 +00:00
|
|
|
if (!parseDatabaseAndTableName(pos, expected, command->from_database, command->from_table))
|
|
|
|
return false;
|
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
command->replace = true;
|
2019-05-28 21:17:48 +00:00
|
|
|
command->type = ASTAlterCommand::REPLACE_PARTITION;
|
|
|
|
}
|
2021-08-20 17:59:57 +00:00
|
|
|
else if (s_attach_part.ignore(pos, expected))
|
2019-05-28 21:17:48 +00:00
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_string_and_substituion.parse(pos, command_partition, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
|
|
|
|
|
|
|
command->part = true;
|
2019-05-28 21:17:48 +00:00
|
|
|
command->type = ASTAlterCommand::ATTACH_PARTITION;
|
|
|
|
}
|
2021-08-20 17:59:57 +00:00
|
|
|
else if (s_fetch_partition.ignore(pos, expected))
|
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_partition.parse(pos, command_partition, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
2014-08-07 11:46:01 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
if (!s_from.ignore(pos, expected))
|
|
|
|
return false;
|
2018-05-21 13:49:54 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
ASTPtr ast_from;
|
|
|
|
if (!parser_string_literal.parse(pos, ast_from, expected))
|
|
|
|
return false;
|
2018-05-21 13:49:54 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
command->from = ast_from->as<ASTLiteral &>().value.get<const String &>();
|
|
|
|
command->type = ASTAlterCommand::FETCH_PARTITION;
|
|
|
|
}
|
|
|
|
else if (s_fetch_part.ignore(pos, expected))
|
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_string_and_substituion.parse(pos, command_partition, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
2014-10-09 20:28:33 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
if (!s_from.ignore(pos, expected))
|
|
|
|
return false;
|
2014-10-09 20:28:33 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
ASTPtr ast_from;
|
|
|
|
if (!parser_string_literal.parse(pos, ast_from, expected))
|
|
|
|
return false;
|
|
|
|
command->from = ast_from->as<ASTLiteral &>().value.get<const String &>();
|
|
|
|
command->part = true;
|
|
|
|
command->type = ASTAlterCommand::FETCH_PARTITION;
|
|
|
|
}
|
|
|
|
else if (s_freeze.ignore(pos, expected))
|
|
|
|
{
|
|
|
|
if (s_partition.ignore(pos, expected))
|
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_partition.parse(pos, command_partition, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
2014-10-09 20:28:33 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
command->type = ASTAlterCommand::FREEZE_PARTITION;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
command->type = ASTAlterCommand::FREEZE_ALL;
|
|
|
|
}
|
2014-10-09 20:28:33 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
/// WITH NAME 'name' - place local backup to directory with specified name
|
|
|
|
if (s_with.ignore(pos, expected))
|
|
|
|
{
|
|
|
|
if (!s_name.ignore(pos, expected))
|
|
|
|
return false;
|
2021-04-13 04:40:33 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
ASTPtr ast_with_name;
|
|
|
|
if (!parser_string_literal.parse(pos, ast_with_name, expected))
|
|
|
|
return false;
|
2021-04-13 04:40:33 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
command->with_name = ast_with_name->as<ASTLiteral &>().value.get<const String &>();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (s_unfreeze.ignore(pos, expected))
|
2019-05-28 21:17:48 +00:00
|
|
|
{
|
2021-08-20 17:59:57 +00:00
|
|
|
if (s_partition.ignore(pos, expected))
|
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_partition.parse(pos, command_partition, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
2019-05-28 21:17:48 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
command->type = ASTAlterCommand::UNFREEZE_PARTITION;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
command->type = ASTAlterCommand::UNFREEZE_ALL;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// WITH NAME 'name' - remove local backup to directory with specified name
|
|
|
|
if (s_with.ignore(pos, expected))
|
|
|
|
{
|
|
|
|
if (!s_name.ignore(pos, expected))
|
|
|
|
return false;
|
|
|
|
|
|
|
|
ASTPtr ast_with_name;
|
|
|
|
if (!parser_string_literal.parse(pos, ast_with_name, expected))
|
|
|
|
return false;
|
|
|
|
|
|
|
|
command->with_name = ast_with_name->as<ASTLiteral &>().value.get<const String &>();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
2019-05-28 21:17:48 +00:00
|
|
|
}
|
2021-11-30 13:07:14 +00:00
|
|
|
else if (bool is_modify = s_modify_column.ignore(pos, expected); is_modify || s_alter_column.ignore(pos, expected))
|
2019-05-28 21:17:48 +00:00
|
|
|
{
|
2021-08-20 17:59:57 +00:00
|
|
|
if (s_if_exists.ignore(pos, expected))
|
|
|
|
command->if_exists = true;
|
2019-05-28 21:17:48 +00:00
|
|
|
|
2021-11-30 13:07:14 +00:00
|
|
|
if (!is_modify)
|
|
|
|
parser_modify_col_decl.enableCheckTypeKeyword();
|
|
|
|
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_modify_col_decl.parse(pos, command_col_decl, expected))
|
2019-05-28 21:17:48 +00:00
|
|
|
return false;
|
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
if (s_remove.ignore(pos, expected))
|
|
|
|
{
|
|
|
|
if (s_default.ignore(pos, expected))
|
|
|
|
command->remove_property = "DEFAULT";
|
|
|
|
else if (s_materialized.ignore(pos, expected))
|
|
|
|
command->remove_property = "MATERIALIZED";
|
|
|
|
else if (s_alias.ignore(pos, expected))
|
|
|
|
command->remove_property = "ALIAS";
|
|
|
|
else if (s_comment.ignore(pos, expected))
|
|
|
|
command->remove_property = "COMMENT";
|
|
|
|
else if (s_codec.ignore(pos, expected))
|
|
|
|
command->remove_property = "CODEC";
|
|
|
|
else if (s_ttl.ignore(pos, expected))
|
|
|
|
command->remove_property = "TTL";
|
2024-01-18 05:17:07 +00:00
|
|
|
else if (s_settings.ignore(pos, expected))
|
|
|
|
command->remove_property = "SETTINGS";
|
2021-08-20 17:59:57 +00:00
|
|
|
else
|
|
|
|
return false;
|
|
|
|
}
|
2024-01-18 05:17:07 +00:00
|
|
|
else if (s_modify_setting.ignore(pos, expected))
|
|
|
|
{
|
2024-01-18 19:52:13 +00:00
|
|
|
if (!parser_settings.parse(pos, command_settings_changes, expected))
|
2024-01-18 05:17:07 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
else if (s_reset_setting.ignore(pos, expected))
|
|
|
|
{
|
2024-01-18 19:52:13 +00:00
|
|
|
if (!parser_reset_setting.parse(pos, command_settings_resets, expected))
|
2024-01-18 05:17:07 +00:00
|
|
|
return false;
|
|
|
|
}
|
2021-08-20 17:59:57 +00:00
|
|
|
else
|
|
|
|
{
|
|
|
|
if (s_first.ignore(pos, expected))
|
|
|
|
command->first = true;
|
|
|
|
else if (s_after.ignore(pos, expected))
|
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_name.parse(pos, command_column, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
command->type = ASTAlterCommand::MODIFY_COLUMN;
|
|
|
|
}
|
|
|
|
else if (s_modify_order_by.ignore(pos, expected))
|
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_exp_elem.parse(pos, command_order_by, expected))
|
2019-05-28 21:17:48 +00:00
|
|
|
return false;
|
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
command->type = ASTAlterCommand::MODIFY_ORDER_BY;
|
2019-05-28 21:17:48 +00:00
|
|
|
}
|
2021-08-20 17:59:57 +00:00
|
|
|
else if (s_modify_sample_by.ignore(pos, expected))
|
2021-03-02 20:28:42 +00:00
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_exp_elem.parse(pos, command_sample_by, expected))
|
2021-03-02 20:28:42 +00:00
|
|
|
return false;
|
2021-02-24 14:26:46 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
command->type = ASTAlterCommand::MODIFY_SAMPLE_BY;
|
2021-03-02 20:28:42 +00:00
|
|
|
}
|
2021-10-14 13:44:28 +00:00
|
|
|
else if (s_remove_sample_by.ignore(pos, expected))
|
|
|
|
{
|
|
|
|
command->type = ASTAlterCommand::REMOVE_SAMPLE_BY;
|
|
|
|
}
|
2021-08-20 17:59:57 +00:00
|
|
|
else if (s_delete.ignore(pos, expected))
|
2021-03-02 20:28:42 +00:00
|
|
|
{
|
2021-08-20 17:59:57 +00:00
|
|
|
if (s_in_partition.ignore(pos, expected))
|
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_partition.parse(pos, command_partition, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
|
|
|
}
|
2021-03-02 20:28:42 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
if (!s_where.ignore(pos, expected))
|
2021-03-02 20:28:42 +00:00
|
|
|
return false;
|
|
|
|
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_exp_elem.parse(pos, command_predicate, expected))
|
2021-03-02 20:28:42 +00:00
|
|
|
return false;
|
2021-02-24 14:26:46 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
command->type = ASTAlterCommand::DELETE;
|
2021-03-02 20:28:42 +00:00
|
|
|
}
|
2021-08-20 17:59:57 +00:00
|
|
|
else if (s_update.ignore(pos, expected))
|
2021-03-02 20:28:42 +00:00
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_assignment_list.parse(pos, command_update_assignments, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
|
|
|
|
|
|
|
if (s_in_partition.ignore(pos, expected))
|
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_partition.parse(pos, command_partition, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!s_where.ignore(pos, expected))
|
|
|
|
return false;
|
|
|
|
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_exp_elem.parse(pos, command_predicate, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
|
|
|
|
|
|
|
command->type = ASTAlterCommand::UPDATE;
|
2021-03-02 20:28:42 +00:00
|
|
|
}
|
2021-08-20 17:59:57 +00:00
|
|
|
else if (s_comment_column.ignore(pos, expected))
|
|
|
|
{
|
|
|
|
if (s_if_exists.ignore(pos, expected))
|
|
|
|
command->if_exists = true;
|
2018-12-21 14:53:00 +00:00
|
|
|
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_name.parse(pos, command_column, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
2016-06-28 20:50:37 +00:00
|
|
|
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_string_literal.parse(pos, command_comment, expected))
|
2020-07-01 14:58:52 +00:00
|
|
|
return false;
|
2021-08-20 17:59:57 +00:00
|
|
|
|
|
|
|
command->type = ASTAlterCommand::COMMENT_COLUMN;
|
2020-07-01 14:58:52 +00:00
|
|
|
}
|
2021-08-20 17:59:57 +00:00
|
|
|
else if (s_modify_ttl.ignore(pos, expected))
|
2020-09-20 13:27:33 +00:00
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_ttl_list.parse(pos, command_ttl, expected))
|
2021-08-20 17:59:57 +00:00
|
|
|
return false;
|
|
|
|
command->type = ASTAlterCommand::MODIFY_TTL;
|
|
|
|
}
|
|
|
|
else if (s_remove_ttl.ignore(pos, expected))
|
|
|
|
{
|
|
|
|
command->type = ASTAlterCommand::REMOVE_TTL;
|
|
|
|
}
|
|
|
|
else if (s_materialize_ttl.ignore(pos, expected))
|
|
|
|
{
|
|
|
|
command->type = ASTAlterCommand::MATERIALIZE_TTL;
|
|
|
|
|
|
|
|
if (s_in_partition.ignore(pos, expected))
|
2020-09-20 13:27:33 +00:00
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_partition.parse(pos, command_partition, expected))
|
2020-09-20 13:27:33 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
2021-08-20 17:59:57 +00:00
|
|
|
else if (s_modify_setting.ignore(pos, expected))
|
2020-11-10 10:23:46 +00:00
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_settings.parse(pos, command_settings_changes, expected))
|
2020-11-10 10:23:46 +00:00
|
|
|
return false;
|
2021-08-20 17:59:57 +00:00
|
|
|
command->type = ASTAlterCommand::MODIFY_SETTING;
|
2020-11-10 10:23:46 +00:00
|
|
|
}
|
2021-08-20 17:59:57 +00:00
|
|
|
else if (s_reset_setting.ignore(pos, expected))
|
2020-11-10 10:23:46 +00:00
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_reset_setting.parse(pos, command_settings_resets, expected))
|
2020-11-10 10:23:46 +00:00
|
|
|
return false;
|
2021-08-20 17:59:57 +00:00
|
|
|
command->type = ASTAlterCommand::RESET_SETTING;
|
2020-11-10 10:23:46 +00:00
|
|
|
}
|
2021-08-20 17:59:57 +00:00
|
|
|
else if (s_modify_query.ignore(pos, expected))
|
2020-03-10 11:17:26 +00:00
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!select_p.parse(pos, command_select, expected))
|
2020-03-10 11:17:26 +00:00
|
|
|
return false;
|
2021-08-20 17:59:57 +00:00
|
|
|
command->type = ASTAlterCommand::MODIFY_QUERY;
|
2020-03-10 11:17:26 +00:00
|
|
|
}
|
2024-02-22 16:47:50 +00:00
|
|
|
else if (s_modify_sql_security.ignore(pos, expected))
|
|
|
|
{
|
|
|
|
/// This is a hack so we can reuse parser from create and don't have to write `MODIFY SQL SECURITY SQL SECURITY INVOKER`
|
|
|
|
pos -= 2;
|
|
|
|
if (!sql_security_p.parse(pos, command_sql_security, expected))
|
|
|
|
return false;
|
|
|
|
command->type = ASTAlterCommand::MODIFY_SQL_SECURITY;
|
|
|
|
}
|
2023-11-29 02:32:41 +00:00
|
|
|
else if (s_modify_refresh.ignore(pos, expected))
|
|
|
|
{
|
|
|
|
if (!refresh_p.parse(pos, command->refresh, expected))
|
|
|
|
return false;
|
|
|
|
command->type = ASTAlterCommand::MODIFY_REFRESH;
|
|
|
|
}
|
2021-09-20 11:06:19 +00:00
|
|
|
else if (s_modify_comment.ignore(pos, expected))
|
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_string_literal.parse(pos, command_comment, expected))
|
2021-09-20 11:06:19 +00:00
|
|
|
return false;
|
|
|
|
|
|
|
|
command->type = ASTAlterCommand::MODIFY_COMMENT;
|
|
|
|
}
|
2023-12-01 19:12:05 +00:00
|
|
|
else if (s_apply_deleted_mask.ignore(pos, expected))
|
|
|
|
{
|
|
|
|
command->type = ASTAlterCommand::APPLY_DELETED_MASK;
|
|
|
|
|
|
|
|
if (s_in_partition.ignore(pos, expected))
|
|
|
|
{
|
2023-12-27 17:13:16 +00:00
|
|
|
if (!parser_partition.parse(pos, command_partition, expected))
|
2023-12-01 19:12:05 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
2021-08-20 17:59:57 +00:00
|
|
|
else
|
2020-01-29 17:44:16 +00:00
|
|
|
return false;
|
|
|
|
}
|
2019-04-15 09:30:45 +00:00
|
|
|
}
|
2016-05-17 20:11:43 +00:00
|
|
|
|
2023-12-27 17:13:16 +00:00
|
|
|
if (command_col_decl)
|
|
|
|
command->col_decl = command->children.emplace_back(std::move(command_col_decl)).get();
|
|
|
|
if (command_column)
|
|
|
|
command->column = command->children.emplace_back(std::move(command_column)).get();
|
|
|
|
if (command_order_by)
|
|
|
|
command->order_by = command->children.emplace_back(std::move(command_order_by)).get();
|
|
|
|
if (command_sample_by)
|
|
|
|
command->sample_by = command->children.emplace_back(std::move(command_sample_by)).get();
|
|
|
|
if (command_index_decl)
|
|
|
|
command->index_decl = command->children.emplace_back(std::move(command_index_decl)).get();
|
|
|
|
if (command_index)
|
|
|
|
command->index = command->children.emplace_back(std::move(command_index)).get();
|
|
|
|
if (command_constraint_decl)
|
|
|
|
command->constraint_decl = command->children.emplace_back(std::move(command_constraint_decl)).get();
|
|
|
|
if (command_constraint)
|
|
|
|
command->constraint = command->children.emplace_back(std::move(command_constraint)).get();
|
|
|
|
if (command_projection_decl)
|
|
|
|
command->projection_decl = command->children.emplace_back(std::move(command_projection_decl)).get();
|
|
|
|
if (command_projection)
|
|
|
|
command->projection = command->children.emplace_back(std::move(command_projection)).get();
|
|
|
|
if (command_statistic_decl)
|
|
|
|
command->statistic_decl = command->children.emplace_back(std::move(command_statistic_decl)).get();
|
|
|
|
if (command_partition)
|
|
|
|
command->partition = command->children.emplace_back(std::move(command_partition)).get();
|
|
|
|
if (command_predicate)
|
|
|
|
command->predicate = command->children.emplace_back(std::move(command_predicate)).get();
|
|
|
|
if (command_update_assignments)
|
|
|
|
command->update_assignments = command->children.emplace_back(std::move(command_update_assignments)).get();
|
|
|
|
if (command_comment)
|
|
|
|
command->comment = command->children.emplace_back(std::move(command_comment)).get();
|
|
|
|
if (command_ttl)
|
|
|
|
command->ttl = command->children.emplace_back(std::move(command_ttl)).get();
|
|
|
|
if (command_settings_changes)
|
|
|
|
command->settings_changes = command->children.emplace_back(std::move(command_settings_changes)).get();
|
|
|
|
if (command_settings_resets)
|
|
|
|
command->settings_resets = command->children.emplace_back(std::move(command_settings_resets)).get();
|
|
|
|
if (command_select)
|
|
|
|
command->select = command->children.emplace_back(std::move(command_select)).get();
|
|
|
|
if (command_values)
|
|
|
|
command->values = command->children.emplace_back(std::move(command_values)).get();
|
2024-02-22 16:47:50 +00:00
|
|
|
if (command_sql_security)
|
|
|
|
command->sql_security = command->children.emplace_back(std::move(command_sql_security)).get();
|
2023-12-27 17:13:16 +00:00
|
|
|
if (command_rename_to)
|
|
|
|
command->rename_to = command->children.emplace_back(std::move(command_rename_to)).get();
|
2016-05-05 18:28:46 +00:00
|
|
|
|
2018-06-09 15:53:14 +00:00
|
|
|
return true;
|
|
|
|
}
|
2018-02-02 16:02:43 +00:00
|
|
|
|
2013-08-07 13:07:42 +00:00
|
|
|
|
2018-06-09 15:53:14 +00:00
|
|
|
bool ParserAlterCommandList::parseImpl(Pos & pos, ASTPtr & node, Expected & expected)
|
|
|
|
{
|
2020-12-04 02:15:44 +00:00
|
|
|
auto command_list = std::make_shared<ASTExpressionList>();
|
2018-06-09 15:53:14 +00:00
|
|
|
node = command_list;
|
|
|
|
|
|
|
|
ParserToken s_comma(TokenType::Comma);
|
2022-06-17 07:46:44 +00:00
|
|
|
ParserAlterCommand p_command(alter_object);
|
2018-06-09 15:53:14 +00:00
|
|
|
|
|
|
|
do
|
|
|
|
{
|
|
|
|
ASTPtr command;
|
|
|
|
if (!p_command.parse(pos, command, expected))
|
|
|
|
return false;
|
2013-08-07 13:07:42 +00:00
|
|
|
|
2020-12-04 02:15:44 +00:00
|
|
|
command_list->children.push_back(command);
|
2017-04-01 07:20:54 +00:00
|
|
|
}
|
2018-06-09 15:53:14 +00:00
|
|
|
while (s_comma.ignore(pos, expected));
|
2013-08-07 13:07:42 +00:00
|
|
|
|
2018-06-09 15:53:14 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool ParserAlterQuery::parseImpl(Pos & pos, ASTPtr & node, Expected & expected)
|
|
|
|
{
|
|
|
|
auto query = std::make_shared<ASTAlterQuery>();
|
2017-04-01 07:20:54 +00:00
|
|
|
node = query;
|
2013-08-07 13:07:42 +00:00
|
|
|
|
2018-06-09 15:53:14 +00:00
|
|
|
ParserKeyword s_alter_table("ALTER TABLE");
|
2023-11-16 21:24:58 +00:00
|
|
|
ParserKeyword s_alter_temporary_table("ALTER TEMPORARY TABLE");
|
2019-05-28 21:17:48 +00:00
|
|
|
ParserKeyword s_alter_live_view("ALTER LIVE VIEW");
|
2021-08-20 17:59:57 +00:00
|
|
|
ParserKeyword s_alter_database("ALTER DATABASE");
|
2019-05-28 21:17:48 +00:00
|
|
|
|
2021-08-20 17:59:57 +00:00
|
|
|
ASTAlterQuery::AlterObjectType alter_object_type;
|
2019-05-28 21:17:48 +00:00
|
|
|
|
2023-11-16 21:24:58 +00:00
|
|
|
if (s_alter_table.ignore(pos, expected) || s_alter_temporary_table.ignore(pos, expected))
|
2019-05-28 21:17:48 +00:00
|
|
|
{
|
2021-08-20 17:59:57 +00:00
|
|
|
alter_object_type = ASTAlterQuery::AlterObjectType::TABLE;
|
2019-05-28 21:17:48 +00:00
|
|
|
}
|
2021-08-20 17:59:57 +00:00
|
|
|
else if (s_alter_live_view.ignore(pos, expected))
|
|
|
|
{
|
|
|
|
alter_object_type = ASTAlterQuery::AlterObjectType::LIVE_VIEW;
|
|
|
|
}
|
|
|
|
else if (s_alter_database.ignore(pos, expected))
|
|
|
|
{
|
|
|
|
alter_object_type = ASTAlterQuery::AlterObjectType::DATABASE;
|
|
|
|
}
|
|
|
|
else
|
2018-06-09 15:53:14 +00:00
|
|
|
return false;
|
|
|
|
|
2021-08-27 06:30:21 +00:00
|
|
|
if (alter_object_type == ASTAlterQuery::AlterObjectType::DATABASE)
|
2018-06-09 15:53:14 +00:00
|
|
|
{
|
2021-11-16 08:58:28 +00:00
|
|
|
if (!parseDatabaseAsAST(pos, expected, query->database))
|
2018-06-09 15:53:14 +00:00
|
|
|
return false;
|
|
|
|
}
|
2021-08-27 06:30:21 +00:00
|
|
|
else
|
2018-06-09 15:53:14 +00:00
|
|
|
{
|
2021-11-16 08:58:28 +00:00
|
|
|
if (!parseDatabaseAndTableAsAST(pos, expected, query->database, query->table))
|
2018-06-09 15:53:14 +00:00
|
|
|
return false;
|
2021-08-27 06:30:21 +00:00
|
|
|
|
|
|
|
String cluster_str;
|
|
|
|
if (ParserKeyword{"ON"}.ignore(pos, expected))
|
|
|
|
{
|
|
|
|
if (!ASTQueryWithOnCluster::parse(pos, cluster_str, expected))
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
query->cluster = cluster_str;
|
2018-06-09 15:53:14 +00:00
|
|
|
}
|
|
|
|
|
2022-06-17 07:46:44 +00:00
|
|
|
ParserAlterCommandList p_command_list(alter_object_type);
|
2018-06-09 15:53:14 +00:00
|
|
|
ASTPtr command_list;
|
|
|
|
if (!p_command_list.parse(pos, command_list, expected))
|
|
|
|
return false;
|
|
|
|
|
|
|
|
query->set(query->command_list, command_list);
|
2021-08-27 06:30:21 +00:00
|
|
|
query->alter_object = alter_object_type;
|
2018-06-09 15:53:14 +00:00
|
|
|
|
2021-09-06 22:13:54 +00:00
|
|
|
if (query->database)
|
|
|
|
query->children.push_back(query->database);
|
|
|
|
|
|
|
|
if (query->table)
|
|
|
|
query->children.push_back(query->table);
|
|
|
|
|
2017-04-01 07:20:54 +00:00
|
|
|
return true;
|
2013-08-07 13:07:42 +00:00
|
|
|
}
|
2018-08-07 13:58:11 +00:00
|
|
|
|
2013-08-07 13:07:42 +00:00
|
|
|
}
|