2011-08-18 18:48:00 +00:00
|
|
|
#pragma once
|
|
|
|
|
2017-04-01 09:19:00 +00:00
|
|
|
#include <Parsers/IParserBase.h>
|
|
|
|
#include <Parsers/ExpressionElementParsers.h>
|
|
|
|
#include <Parsers/ExpressionListParsers.h>
|
|
|
|
#include <Parsers/ASTNameTypePair.h>
|
|
|
|
#include <Parsers/ASTColumnDeclaration.h>
|
2021-11-26 15:49:40 +00:00
|
|
|
#include <Parsers/ASTIdentifier_fwd.h>
|
2017-04-01 09:19:00 +00:00
|
|
|
#include <Parsers/CommonParsers.h>
|
2020-06-18 12:52:05 +00:00
|
|
|
#include <Parsers/ParserDataType.h>
|
2014-10-07 09:09:59 +00:00
|
|
|
#include <Poco/String.h>
|
2011-08-18 18:48:00 +00:00
|
|
|
|
|
|
|
|
|
|
|
namespace DB
|
|
|
|
{
|
|
|
|
|
2017-05-27 17:29:55 +00:00
|
|
|
/** A nested table. For example, Nested(UInt32 CounterID, FixedString(2) UserAgentMajor)
|
2013-07-11 17:35:56 +00:00
|
|
|
*/
|
|
|
|
class ParserNestedTable : public IParserBase
|
|
|
|
{
|
|
|
|
protected:
|
2020-01-21 08:54:26 +00:00
|
|
|
const char * getName() const override { return "nested table"; }
|
|
|
|
bool parseImpl(Pos & pos, ASTPtr & node, Expected & expected) override;
|
2013-07-11 17:35:56 +00:00
|
|
|
};
|
|
|
|
|
2014-06-26 00:58:14 +00:00
|
|
|
|
2020-06-18 12:52:05 +00:00
|
|
|
/** Storage engine or Codec. For example:
|
|
|
|
* Memory()
|
|
|
|
* ReplicatedMergeTree('/path', 'replica')
|
2017-05-27 17:29:55 +00:00
|
|
|
* Result of parsing - ASTFunction with or without parameters.
|
|
|
|
*/
|
2013-07-11 17:35:56 +00:00
|
|
|
class ParserIdentifierWithParameters : public IParserBase
|
|
|
|
{
|
|
|
|
protected:
|
2020-01-21 08:54:26 +00:00
|
|
|
const char * getName() const override { return "identifier with parameters"; }
|
|
|
|
bool parseImpl(Pos & pos, ASTPtr & node, Expected & expected) override;
|
2013-07-11 17:35:56 +00:00
|
|
|
};
|
|
|
|
|
2017-09-15 12:16:12 +00:00
|
|
|
template <typename NameParser>
|
2014-05-20 16:46:33 +00:00
|
|
|
class IParserNameTypePair : public IParserBase
|
2011-08-18 18:48:00 +00:00
|
|
|
{
|
|
|
|
protected:
|
2020-01-21 08:54:26 +00:00
|
|
|
const char * getName() const override{ return "name and type pair"; }
|
|
|
|
bool parseImpl(Pos & pos, ASTPtr & node, Expected & expected) override;
|
2011-08-18 18:48:00 +00:00
|
|
|
};
|
|
|
|
|
2017-05-27 17:29:55 +00:00
|
|
|
/** The name and type are separated by a space. For example, URL String. */
|
2016-05-28 10:35:44 +00:00
|
|
|
using ParserNameTypePair = IParserNameTypePair<ParserIdentifier>;
|
2014-05-20 16:46:33 +00:00
|
|
|
|
2017-09-15 12:16:12 +00:00
|
|
|
template <typename NameParser>
|
2017-07-10 03:28:12 +00:00
|
|
|
bool IParserNameTypePair<NameParser>::parseImpl(Pos & pos, ASTPtr & node, Expected & expected)
|
2014-05-20 16:46:33 +00:00
|
|
|
{
|
2017-04-01 07:20:54 +00:00
|
|
|
NameParser name_parser;
|
2020-06-18 12:52:05 +00:00
|
|
|
ParserDataType type_parser;
|
2017-04-01 07:20:54 +00:00
|
|
|
|
|
|
|
ASTPtr name, type;
|
2017-07-10 03:28:12 +00:00
|
|
|
if (name_parser.parse(pos, name, expected)
|
|
|
|
&& type_parser.parse(pos, type, expected))
|
2017-04-01 07:20:54 +00:00
|
|
|
{
|
2018-02-26 03:40:20 +00:00
|
|
|
auto name_type_pair = std::make_shared<ASTNameTypePair>();
|
2019-08-08 20:02:30 +00:00
|
|
|
tryGetIdentifierNameInto(name, name_type_pair->name);
|
2017-04-01 07:20:54 +00:00
|
|
|
name_type_pair->type = type;
|
|
|
|
name_type_pair->children.push_back(type);
|
|
|
|
node = name_type_pair;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
2014-05-20 16:46:33 +00:00
|
|
|
}
|
2011-08-18 18:48:00 +00:00
|
|
|
|
2017-05-27 17:29:55 +00:00
|
|
|
/** List of columns. */
|
2013-07-11 17:35:56 +00:00
|
|
|
class ParserNameTypePairList : public IParserBase
|
|
|
|
{
|
|
|
|
protected:
|
2020-01-21 08:54:26 +00:00
|
|
|
const char * getName() const override { return "name and type pair list"; }
|
|
|
|
bool parseImpl(Pos & pos, ASTPtr & node, Expected & expected) override;
|
2014-09-24 14:44:57 +00:00
|
|
|
};
|
|
|
|
|
2019-05-28 21:17:48 +00:00
|
|
|
/** List of table names. */
|
|
|
|
class ParserNameList : public IParserBase
|
|
|
|
{
|
|
|
|
protected:
|
2020-01-21 08:54:26 +00:00
|
|
|
const char * getName() const override { return "name list"; }
|
|
|
|
bool parseImpl(Pos & pos, ASTPtr & node, Expected & expected) override;
|
2019-05-28 21:17:48 +00:00
|
|
|
};
|
|
|
|
|
2014-09-24 14:44:57 +00:00
|
|
|
|
2017-09-15 12:16:12 +00:00
|
|
|
template <typename NameParser>
|
2014-09-24 14:44:57 +00:00
|
|
|
class IParserColumnDeclaration : public IParserBase
|
|
|
|
{
|
2018-11-14 22:46:39 +00:00
|
|
|
public:
|
2020-09-20 13:27:33 +00:00
|
|
|
explicit IParserColumnDeclaration(bool require_type_ = true, bool allow_null_modifiers_ = false, bool check_keywords_after_name_ = false)
|
|
|
|
: require_type(require_type_)
|
|
|
|
, allow_null_modifiers(allow_null_modifiers_)
|
|
|
|
, check_keywords_after_name(check_keywords_after_name_)
|
2018-11-14 22:46:39 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2021-11-30 13:07:14 +00:00
|
|
|
void enableCheckTypeKeyword() { check_type_keyword = true; }
|
|
|
|
|
2014-09-24 14:44:57 +00:00
|
|
|
protected:
|
2018-10-11 02:57:48 +00:00
|
|
|
using ASTDeclarePtr = std::shared_ptr<ASTColumnDeclaration>;
|
|
|
|
|
2020-01-21 08:54:26 +00:00
|
|
|
const char * getName() const override{ return "column declaration"; }
|
2018-10-11 02:57:48 +00:00
|
|
|
|
2020-01-21 08:54:26 +00:00
|
|
|
bool parseImpl(Pos & pos, ASTPtr & node, Expected & expected) override;
|
2018-11-14 22:46:39 +00:00
|
|
|
|
|
|
|
bool require_type = true;
|
2020-06-14 16:17:22 +00:00
|
|
|
bool allow_null_modifiers = false;
|
2020-09-20 13:27:33 +00:00
|
|
|
bool check_keywords_after_name = false;
|
2021-11-30 13:07:14 +00:00
|
|
|
/// just for ALTER TABLE ALTER COLUMN use
|
|
|
|
bool check_type_keyword = false;
|
2014-09-24 14:44:57 +00:00
|
|
|
};
|
|
|
|
|
2016-05-28 10:35:44 +00:00
|
|
|
using ParserColumnDeclaration = IParserColumnDeclaration<ParserIdentifier>;
|
|
|
|
using ParserCompoundColumnDeclaration = IParserColumnDeclaration<ParserCompoundIdentifier>;
|
2014-09-24 14:44:57 +00:00
|
|
|
|
2017-09-15 12:16:12 +00:00
|
|
|
template <typename NameParser>
|
2017-07-10 03:28:12 +00:00
|
|
|
bool IParserColumnDeclaration<NameParser>::parseImpl(Pos & pos, ASTPtr & node, Expected & expected)
|
2014-09-24 14:44:57 +00:00
|
|
|
{
|
2017-04-01 07:20:54 +00:00
|
|
|
NameParser name_parser;
|
2020-06-18 12:52:05 +00:00
|
|
|
ParserDataType type_parser;
|
2018-12-13 15:26:28 +00:00
|
|
|
ParserKeyword s_default{"DEFAULT"};
|
2020-05-20 01:22:32 +00:00
|
|
|
ParserKeyword s_null{"NULL"};
|
2020-05-23 14:32:47 +00:00
|
|
|
ParserKeyword s_not{"NOT"};
|
2018-12-13 15:26:28 +00:00
|
|
|
ParserKeyword s_materialized{"MATERIALIZED"};
|
2022-02-07 23:21:10 +00:00
|
|
|
ParserKeyword s_ephemeral{"EPHEMERAL"};
|
2018-12-13 15:26:28 +00:00
|
|
|
ParserKeyword s_alias{"ALIAS"};
|
|
|
|
ParserKeyword s_comment{"COMMENT"};
|
|
|
|
ParserKeyword s_codec{"CODEC"};
|
2019-04-15 09:30:45 +00:00
|
|
|
ParserKeyword s_ttl{"TTL"};
|
2020-09-20 13:27:33 +00:00
|
|
|
ParserKeyword s_remove{"REMOVE"};
|
2021-11-30 13:07:14 +00:00
|
|
|
ParserKeyword s_type{"TYPE"};
|
2018-12-13 15:26:28 +00:00
|
|
|
ParserTernaryOperatorExpression expr_parser;
|
|
|
|
ParserStringLiteral string_literal_parser;
|
|
|
|
ParserCodec codec_parser;
|
2019-04-15 09:30:45 +00:00
|
|
|
ParserExpression expression_parser;
|
2017-04-01 07:20:54 +00:00
|
|
|
|
2018-12-13 15:26:28 +00:00
|
|
|
/// mandatory column name
|
|
|
|
ASTPtr name;
|
|
|
|
if (!name_parser.parse(pos, name, expected))
|
2017-04-01 07:20:54 +00:00
|
|
|
return false;
|
|
|
|
|
2020-09-20 13:27:33 +00:00
|
|
|
const auto column_declaration = std::make_shared<ASTColumnDeclaration>();
|
|
|
|
tryGetIdentifierNameInto(name, column_declaration->name);
|
|
|
|
|
|
|
|
/// This keyword may occur only in MODIFY COLUMN query. We check it here
|
|
|
|
/// because ParserDataType parses types as an arbitrary identifiers and
|
|
|
|
/// doesn't check that parsed string is existing data type. In this way
|
|
|
|
/// REMOVE keyword can be parsed as data type and further parsing will fail.
|
|
|
|
/// So we just check this keyword and in case of success return column
|
2020-11-06 18:19:57 +00:00
|
|
|
/// declaration with name only.
|
|
|
|
if (!require_type && s_remove.checkWithoutMoving(pos, expected))
|
2020-09-20 13:27:33 +00:00
|
|
|
{
|
|
|
|
if (!check_keywords_after_name)
|
|
|
|
return false;
|
|
|
|
|
|
|
|
node = column_declaration;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2018-12-13 15:26:28 +00:00
|
|
|
/** column name should be followed by type name if it
|
|
|
|
* is not immediately followed by {DEFAULT, MATERIALIZED, ALIAS, COMMENT}
|
|
|
|
*/
|
|
|
|
ASTPtr type;
|
|
|
|
String default_specifier;
|
2020-06-14 16:17:22 +00:00
|
|
|
std::optional<bool> null_modifier;
|
2018-12-13 15:26:28 +00:00
|
|
|
ASTPtr default_expression;
|
|
|
|
ASTPtr comment_expression;
|
|
|
|
ASTPtr codec_expression;
|
2019-04-15 09:30:45 +00:00
|
|
|
ASTPtr ttl_expression;
|
2018-12-13 15:26:28 +00:00
|
|
|
|
2020-11-07 22:23:19 +00:00
|
|
|
if (!s_default.checkWithoutMoving(pos, expected)
|
2020-11-06 18:19:57 +00:00
|
|
|
&& !s_materialized.checkWithoutMoving(pos, expected)
|
2022-02-07 23:21:10 +00:00
|
|
|
&& !s_ephemeral.checkWithoutMoving(pos, expected)
|
2020-11-06 18:19:57 +00:00
|
|
|
&& !s_alias.checkWithoutMoving(pos, expected)
|
2020-11-07 22:23:19 +00:00
|
|
|
&& (require_type
|
|
|
|
|| (!s_comment.checkWithoutMoving(pos, expected)
|
|
|
|
&& !s_codec.checkWithoutMoving(pos, expected))))
|
2018-10-11 02:57:48 +00:00
|
|
|
{
|
2021-11-30 13:07:14 +00:00
|
|
|
if (check_type_keyword && !s_type.ignore(pos, expected))
|
|
|
|
return false;
|
2018-12-13 15:26:28 +00:00
|
|
|
if (!type_parser.parse(pos, type, expected))
|
|
|
|
return false;
|
2018-10-11 02:57:48 +00:00
|
|
|
}
|
|
|
|
|
2018-12-13 15:26:28 +00:00
|
|
|
Pos pos_before_specifier = pos;
|
2022-02-09 13:51:12 +00:00
|
|
|
if (s_default.ignore(pos, expected) || s_materialized.ignore(pos, expected) ||
|
|
|
|
s_ephemeral.ignore(pos, expected) || s_alias.ignore(pos, expected))
|
2018-12-13 15:26:28 +00:00
|
|
|
{
|
|
|
|
default_specifier = Poco::toUpper(std::string{pos_before_specifier->begin, pos_before_specifier->end});
|
2018-10-11 02:57:48 +00:00
|
|
|
|
2018-12-13 15:26:28 +00:00
|
|
|
/// should be followed by an expression
|
|
|
|
if (!expr_parser.parse(pos, default_expression, expected))
|
|
|
|
return false;
|
|
|
|
}
|
2018-10-11 02:57:48 +00:00
|
|
|
|
2018-12-13 15:26:28 +00:00
|
|
|
if (require_type && !type && !default_expression)
|
|
|
|
return false; /// reject column name without type
|
2018-10-11 02:57:48 +00:00
|
|
|
|
2020-06-14 16:17:22 +00:00
|
|
|
if (type && allow_null_modifiers)
|
|
|
|
{
|
|
|
|
if (s_not.ignore(pos, expected))
|
2020-05-27 12:22:12 +00:00
|
|
|
{
|
2020-06-14 16:17:22 +00:00
|
|
|
if (!s_null.ignore(pos, expected))
|
|
|
|
return false;
|
|
|
|
null_modifier.emplace(false);
|
2020-05-23 14:32:47 +00:00
|
|
|
}
|
2020-06-14 16:17:22 +00:00
|
|
|
else if (s_null.ignore(pos, expected))
|
|
|
|
null_modifier.emplace(true);
|
|
|
|
}
|
2020-05-26 20:58:51 +00:00
|
|
|
|
2018-12-13 15:26:28 +00:00
|
|
|
if (s_comment.ignore(pos, expected))
|
2018-11-14 22:46:39 +00:00
|
|
|
{
|
2018-12-13 15:26:28 +00:00
|
|
|
/// should be followed by a string literal
|
|
|
|
if (!string_literal_parser.parse(pos, comment_expression, expected))
|
2018-11-14 22:46:39 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2018-12-13 15:26:28 +00:00
|
|
|
if (s_codec.ignore(pos, expected))
|
2017-04-01 07:20:54 +00:00
|
|
|
{
|
2018-12-13 15:26:28 +00:00
|
|
|
if (!codec_parser.parse(pos, codec_expression, expected))
|
2017-04-01 07:20:54 +00:00
|
|
|
return false;
|
|
|
|
}
|
2018-11-14 22:46:39 +00:00
|
|
|
|
2019-04-15 09:30:45 +00:00
|
|
|
if (s_ttl.ignore(pos, expected))
|
|
|
|
{
|
|
|
|
if (!expression_parser.parse(pos, ttl_expression, expected))
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2018-12-13 15:26:28 +00:00
|
|
|
node = column_declaration;
|
2018-10-11 02:57:48 +00:00
|
|
|
|
2018-12-13 15:26:28 +00:00
|
|
|
if (type)
|
|
|
|
{
|
|
|
|
column_declaration->type = type;
|
|
|
|
column_declaration->children.push_back(std::move(type));
|
|
|
|
}
|
2018-11-14 22:46:39 +00:00
|
|
|
|
2020-06-14 16:17:22 +00:00
|
|
|
column_declaration->null_modifier = null_modifier;
|
2020-05-20 01:22:32 +00:00
|
|
|
|
2018-12-13 15:26:28 +00:00
|
|
|
if (default_expression)
|
|
|
|
{
|
|
|
|
column_declaration->default_specifier = default_specifier;
|
|
|
|
column_declaration->default_expression = default_expression;
|
|
|
|
column_declaration->children.push_back(std::move(default_expression));
|
|
|
|
}
|
2018-11-14 22:46:39 +00:00
|
|
|
|
2018-12-13 15:26:28 +00:00
|
|
|
if (comment_expression)
|
2018-10-01 20:16:50 +00:00
|
|
|
{
|
2018-12-13 15:26:28 +00:00
|
|
|
column_declaration->comment = comment_expression;
|
|
|
|
column_declaration->children.push_back(std::move(comment_expression));
|
|
|
|
}
|
2017-04-01 07:20:54 +00:00
|
|
|
|
2018-12-13 15:26:28 +00:00
|
|
|
if (codec_expression)
|
|
|
|
{
|
|
|
|
column_declaration->codec = codec_expression;
|
|
|
|
column_declaration->children.push_back(std::move(codec_expression));
|
2018-10-01 20:16:50 +00:00
|
|
|
}
|
|
|
|
|
2019-04-15 09:30:45 +00:00
|
|
|
if (ttl_expression)
|
|
|
|
{
|
|
|
|
column_declaration->ttl = ttl_expression;
|
|
|
|
column_declaration->children.push_back(std::move(ttl_expression));
|
|
|
|
}
|
|
|
|
|
2017-04-01 07:20:54 +00:00
|
|
|
return true;
|
2014-09-24 14:44:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
class ParserColumnDeclarationList : public IParserBase
|
|
|
|
{
|
|
|
|
protected:
|
2020-01-21 08:54:26 +00:00
|
|
|
const char * getName() const override { return "column declaration list"; }
|
|
|
|
bool parseImpl(Pos & pos, ASTPtr & node, Expected & expected) override;
|
2013-07-11 17:35:56 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2019-02-05 14:50:25 +00:00
|
|
|
/** name BY expr TYPE typename(arg1, arg2, ...) GRANULARITY value */
|
|
|
|
class ParserIndexDeclaration : public IParserBase
|
|
|
|
{
|
|
|
|
public:
|
2022-02-01 16:59:41 +00:00
|
|
|
ParserIndexDeclaration() = default;
|
2019-02-05 14:50:25 +00:00
|
|
|
|
|
|
|
protected:
|
|
|
|
const char * getName() const override { return "index declaration"; }
|
|
|
|
bool parseImpl(Pos & pos, ASTPtr & node, Expected & expected) override;
|
|
|
|
};
|
|
|
|
|
2019-05-12 11:36:02 +00:00
|
|
|
class ParserConstraintDeclaration : public IParserBase
|
|
|
|
{
|
|
|
|
protected:
|
|
|
|
const char * getName() const override { return "constraint declaration"; }
|
|
|
|
bool parseImpl(Pos & pos, ASTPtr & node, Expected & expected) override;
|
|
|
|
};
|
2019-02-05 14:50:25 +00:00
|
|
|
|
2021-02-10 14:12:49 +00:00
|
|
|
class ParserProjectionDeclaration : public IParserBase
|
|
|
|
{
|
|
|
|
protected:
|
|
|
|
const char * getName() const override { return "projection declaration"; }
|
|
|
|
bool parseImpl(Pos & pos, ASTPtr & node, Expected & expected) override;
|
|
|
|
};
|
|
|
|
|
2019-05-12 11:36:02 +00:00
|
|
|
class ParserTablePropertyDeclaration : public IParserBase
|
2019-02-05 14:50:25 +00:00
|
|
|
{
|
|
|
|
protected:
|
2019-11-20 07:07:27 +00:00
|
|
|
const char * getName() const override { return "table property (column, index, constraint) declaration"; }
|
2019-02-05 14:50:25 +00:00
|
|
|
bool parseImpl(Pos & pos, ASTPtr & node, Expected & expected) override;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
class ParserIndexDeclarationList : public IParserBase
|
|
|
|
{
|
|
|
|
protected:
|
|
|
|
const char * getName() const override { return "index declaration list"; }
|
|
|
|
bool parseImpl(Pos & pos, ASTPtr & node, Expected & expected) override;
|
|
|
|
};
|
|
|
|
|
2019-05-12 11:36:02 +00:00
|
|
|
class ParserConstraintDeclarationList : public IParserBase
|
|
|
|
{
|
|
|
|
protected:
|
|
|
|
const char * getName() const override { return "constraint declaration list"; }
|
|
|
|
bool parseImpl(Pos & pos, ASTPtr & node, Expected & expected) override;
|
|
|
|
};
|
|
|
|
|
2021-02-10 14:12:49 +00:00
|
|
|
class ParserProjectionDeclarationList : public IParserBase
|
|
|
|
{
|
|
|
|
protected:
|
|
|
|
const char * getName() const override { return "projection declaration list"; }
|
|
|
|
bool parseImpl(Pos & pos, ASTPtr & node, Expected & expected) override;
|
|
|
|
};
|
|
|
|
|
2019-02-05 14:50:25 +00:00
|
|
|
|
2019-05-12 11:36:02 +00:00
|
|
|
class ParserTablePropertiesDeclarationList : public IParserBase
|
2019-02-05 14:50:25 +00:00
|
|
|
{
|
2019-07-31 14:06:22 +00:00
|
|
|
protected:
|
2019-02-05 14:50:25 +00:00
|
|
|
const char * getName() const override { return "columns or indices declaration list"; }
|
|
|
|
bool parseImpl(Pos & pos, ASTPtr & node, Expected & expected) override;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2022-01-31 17:10:59 +00:00
|
|
|
* [ENGINE = name] [PARTITION BY expr] [ORDER BY expr] [PRIMARY KEY expr] [SAMPLE BY expr] [SETTINGS name = value, ...]
|
2019-02-05 14:50:25 +00:00
|
|
|
*/
|
2017-09-17 18:49:43 +00:00
|
|
|
class ParserStorage : public IParserBase
|
2011-11-01 15:16:04 +00:00
|
|
|
{
|
|
|
|
protected:
|
2020-01-21 08:54:26 +00:00
|
|
|
const char * getName() const override { return "storage definition"; }
|
|
|
|
bool parseImpl(Pos & pos, ASTPtr & node, Expected & expected) override;
|
2011-11-01 15:16:04 +00:00
|
|
|
};
|
|
|
|
|
2019-10-09 20:09:10 +00:00
|
|
|
/** Query like this:
|
2019-10-23 13:46:38 +00:00
|
|
|
* CREATE|ATTACH TABLE [IF NOT EXISTS] [db.]name [UUID 'uuid'] [ON CLUSTER cluster]
|
2019-10-09 20:09:10 +00:00
|
|
|
* (
|
|
|
|
* name1 type1,
|
|
|
|
* name2 type2,
|
|
|
|
* ...
|
|
|
|
* INDEX name1 expr TYPE type1(args) GRANULARITY value,
|
|
|
|
* ...
|
|
|
|
* ) ENGINE = engine
|
|
|
|
*
|
|
|
|
* Or:
|
2019-10-23 13:46:38 +00:00
|
|
|
* CREATE|ATTACH TABLE [IF NOT EXISTS] [db.]name [UUID 'uuid'] [ON CLUSTER cluster] AS [db2.]name2 [ENGINE = engine]
|
2019-10-09 20:09:10 +00:00
|
|
|
*
|
|
|
|
* Or:
|
2019-10-23 13:46:38 +00:00
|
|
|
* CREATE|ATTACH TABLE [IF NOT EXISTS] [db.]name [UUID 'uuid'] [ON CLUSTER cluster] AS ENGINE = engine SELECT ...
|
2019-10-09 20:09:10 +00:00
|
|
|
*
|
2021-12-15 11:30:57 +00:00
|
|
|
* Or (for engines that supports schema inference):
|
|
|
|
* CREATE|ATTACH TABLE [IF NOT EXISTS] [db.]name [UUID 'uuid'] [ON CLUSTER cluster] ENGINE = engine
|
2019-10-09 20:09:10 +00:00
|
|
|
*/
|
|
|
|
class ParserCreateTableQuery : public IParserBase
|
|
|
|
{
|
|
|
|
protected:
|
2020-01-21 08:54:26 +00:00
|
|
|
const char * getName() const override { return "CREATE TABLE or ATTACH TABLE query"; }
|
|
|
|
bool parseImpl(Pos & pos, ASTPtr & node, Expected & expected) override;
|
2019-10-09 20:09:10 +00:00
|
|
|
};
|
|
|
|
|
2019-11-11 11:34:03 +00:00
|
|
|
/// CREATE|ATTACH LIVE VIEW [IF NOT EXISTS] [db.]name [UUID 'uuid'] [TO [db.]name] AS SELECT ...
|
2019-10-09 20:09:10 +00:00
|
|
|
class ParserCreateLiveViewQuery : public IParserBase
|
|
|
|
{
|
|
|
|
protected:
|
2020-01-21 08:54:26 +00:00
|
|
|
const char * getName() const override { return "CREATE LIVE VIEW query"; }
|
|
|
|
bool parseImpl(Pos & pos, ASTPtr & node, Expected & expected) override;
|
2019-10-09 20:09:10 +00:00
|
|
|
};
|
|
|
|
|
2020-02-14 08:07:03 +00:00
|
|
|
/// CREATE|ATTACH WINDOW VIEW [IF NOT EXISTS] [db.]name [TO [db.]name] [ENGINE [db.]name] [WATERMARK function] AS SELECT ...
|
2020-01-14 03:07:31 +00:00
|
|
|
class ParserCreateWindowViewQuery : public IParserBase
|
|
|
|
{
|
|
|
|
protected:
|
2020-02-02 08:52:15 +00:00
|
|
|
const char * getName() const override { return "CREATE WINDOW VIEW query"; }
|
|
|
|
bool parseImpl(Pos & pos, ASTPtr & node, Expected & expected) override;
|
2020-01-14 03:07:31 +00:00
|
|
|
};
|
|
|
|
|
2021-12-03 09:35:36 +00:00
|
|
|
class ParserTableOverrideDeclaration : public IParserBase
|
|
|
|
{
|
2021-12-16 08:26:37 +00:00
|
|
|
public:
|
|
|
|
const bool is_standalone;
|
2022-02-01 16:59:41 +00:00
|
|
|
explicit ParserTableOverrideDeclaration(bool is_standalone_ = true) : is_standalone(is_standalone_) { }
|
2021-12-16 08:26:37 +00:00
|
|
|
|
2021-12-03 09:35:36 +00:00
|
|
|
protected:
|
|
|
|
const char * getName() const override { return "table override declaration"; }
|
|
|
|
bool parseImpl(Pos & pos, ASTPtr & node, Expected & expected) override;
|
|
|
|
};
|
|
|
|
|
|
|
|
class ParserTableOverridesDeclarationList : public IParserBase
|
|
|
|
{
|
|
|
|
protected:
|
|
|
|
const char * getName() const override { return "table overrides declaration list"; }
|
|
|
|
bool parseImpl(Pos & pos, ASTPtr & node, Expected & expected) override;
|
|
|
|
};
|
|
|
|
|
2019-10-09 20:09:10 +00:00
|
|
|
/// CREATE|ATTACH DATABASE db [ENGINE = engine]
|
|
|
|
class ParserCreateDatabaseQuery : public IParserBase
|
|
|
|
{
|
|
|
|
protected:
|
2020-01-21 08:54:26 +00:00
|
|
|
const char * getName() const override { return "CREATE DATABASE query"; }
|
|
|
|
bool parseImpl(Pos & pos, ASTPtr & node, Expected & expected) override;
|
2019-10-09 20:09:10 +00:00
|
|
|
};
|
|
|
|
|
2019-11-11 11:34:03 +00:00
|
|
|
/// CREATE[OR REPLACE]|ATTACH [[MATERIALIZED] VIEW] | [VIEW]] [IF NOT EXISTS] [db.]name [UUID 'uuid'] [TO [db.]name] [ENGINE = engine] [POPULATE] AS SELECT ...
|
2019-10-09 20:09:10 +00:00
|
|
|
class ParserCreateViewQuery : public IParserBase
|
|
|
|
{
|
|
|
|
protected:
|
2020-01-21 08:54:26 +00:00
|
|
|
const char * getName() const override { return "CREATE VIEW query"; }
|
|
|
|
bool parseImpl(Pos & pos, ASTPtr & node, Expected & expected) override;
|
2019-10-09 20:09:10 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/// Parses complete dictionary create query. Uses ParserDictionary and
|
|
|
|
/// ParserDictionaryAttributeDeclaration. Produces ASTCreateQuery.
|
2020-08-08 00:47:03 +00:00
|
|
|
/// CREATE DICTIONARY [IF NOT EXISTS] [db.]name (attrs) PRIMARY KEY key SOURCE(s(params)) LAYOUT(l(params)) LIFETIME([min v1 max] v2) [RANGE(min v1 max v2)]
|
2019-10-09 20:09:10 +00:00
|
|
|
class ParserCreateDictionaryQuery : public IParserBase
|
|
|
|
{
|
|
|
|
protected:
|
|
|
|
const char * getName() const override { return "CREATE DICTIONARY"; }
|
|
|
|
bool parseImpl(Pos & pos, ASTPtr & node, Expected & expected) override;
|
|
|
|
};
|
|
|
|
|
2011-11-01 15:16:04 +00:00
|
|
|
|
2017-05-27 17:29:55 +00:00
|
|
|
/** Query like this:
|
2011-10-31 06:37:12 +00:00
|
|
|
* CREATE|ATTACH TABLE [IF NOT EXISTS] [db.]name
|
2011-08-18 18:48:00 +00:00
|
|
|
* (
|
2017-04-01 07:20:54 +00:00
|
|
|
* name1 type1,
|
|
|
|
* name2 type2,
|
|
|
|
* ...
|
2019-02-05 14:50:25 +00:00
|
|
|
* INDEX name1 expr TYPE type1(args) GRANULARITY value,
|
|
|
|
* ...
|
2020-10-12 13:55:41 +00:00
|
|
|
* PRIMARY KEY expr
|
2011-08-18 18:48:00 +00:00
|
|
|
* ) ENGINE = engine
|
2011-10-31 06:37:12 +00:00
|
|
|
*
|
2017-05-27 17:29:55 +00:00
|
|
|
* Or:
|
2012-07-12 20:06:45 +00:00
|
|
|
* CREATE|ATTACH TABLE [IF NOT EXISTS] [db.]name AS [db2.]name2 [ENGINE = engine]
|
2011-11-01 15:16:04 +00:00
|
|
|
*
|
2017-05-27 17:29:55 +00:00
|
|
|
* Or:
|
2012-12-11 20:32:08 +00:00
|
|
|
* CREATE|ATTACH TABLE [IF NOT EXISTS] [db.]name AS ENGINE = engine SELECT ...
|
2011-11-05 23:31:19 +00:00
|
|
|
*
|
2017-05-27 17:29:55 +00:00
|
|
|
* Or:
|
2016-03-19 01:18:49 +00:00
|
|
|
* CREATE|ATTACH DATABASE db [ENGINE = engine]
|
2014-04-24 18:49:07 +00:00
|
|
|
*
|
2017-05-27 17:29:55 +00:00
|
|
|
* Or:
|
2019-08-23 05:08:06 +00:00
|
|
|
* CREATE[OR REPLACE]|ATTACH [[MATERIALIZED] VIEW] | [VIEW]] [IF NOT EXISTS] [db.]name [TO [db.]name] [ENGINE = engine] [POPULATE] AS SELECT ...
|
2011-08-18 18:48:00 +00:00
|
|
|
*/
|
|
|
|
class ParserCreateQuery : public IParserBase
|
|
|
|
{
|
|
|
|
protected:
|
2020-01-21 08:54:26 +00:00
|
|
|
const char * getName() const override { return "CREATE TABLE or ATTACH TABLE query"; }
|
|
|
|
bool parseImpl(Pos & pos, ASTPtr & node, Expected & expected) override;
|
2011-08-18 18:48:00 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|