mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-11-27 01:51:59 +00:00
115 lines
2.8 KiB
C++
115 lines
2.8 KiB
C++
#pragma once
|
||
|
||
#include <DB/Parsers/IAST.h>
|
||
|
||
|
||
namespace DB
|
||
{
|
||
|
||
namespace ErrorCodes
|
||
{
|
||
extern const int UNEXPECTED_AST_STRUCTURE;
|
||
}
|
||
|
||
/** ALTER запрос
|
||
* ALTER TABLE [db.]name_type
|
||
* ADD COLUMN col_name type [AFTER col_after],
|
||
* DROP COLUMN col_drop,
|
||
* MODIFY COLUMN col_name type,
|
||
* DROP PARTITION partition
|
||
* RESHARD [COPY] PARTITION partition
|
||
* TO '/path/to/zookeeper/table' [WEIGHT w], ...
|
||
* USING expression
|
||
* [COORDINATE WITH 'coordinator_id']
|
||
*/
|
||
|
||
class ASTAlterQuery : public IAST
|
||
{
|
||
public:
|
||
enum ParameterType
|
||
{
|
||
ADD_COLUMN,
|
||
DROP_COLUMN,
|
||
MODIFY_COLUMN,
|
||
MODIFY_PRIMARY_KEY,
|
||
|
||
DROP_PARTITION,
|
||
ATTACH_PARTITION,
|
||
FETCH_PARTITION,
|
||
FREEZE_PARTITION,
|
||
RESHARD_PARTITION,
|
||
|
||
NO_TYPE,
|
||
};
|
||
|
||
struct Parameters
|
||
{
|
||
Parameters();
|
||
|
||
int type = NO_TYPE;
|
||
|
||
/** В запросе ADD COLUMN здесь хранится имя и тип добавляемого столбца
|
||
* В запросе DROP это поле не используется
|
||
* В запросе MODIFY здесь хранится имя столбца и новый тип
|
||
*/
|
||
ASTPtr col_decl;
|
||
|
||
/** В запросе ADD COLUMN здесь опционально хранится имя столбца, следующее после AFTER
|
||
* В запросе DROP здесь хранится имя столбца для удаления
|
||
*/
|
||
ASTPtr column;
|
||
|
||
/** Для MODIFY PRIMARY KEY
|
||
*/
|
||
ASTPtr primary_key;
|
||
|
||
/** В запросах DROP PARTITION и RESHARD PARTITION здесь хранится имя partition'а.
|
||
*/
|
||
ASTPtr partition;
|
||
bool detach = false; /// true для DETACH PARTITION.
|
||
|
||
bool part = false; /// true для ATTACH [UNREPLICATED] PART
|
||
bool unreplicated = false; /// true для ATTACH UNREPLICATED, DROP UNREPLICATED ...
|
||
|
||
bool do_copy = false; /// для RESHARD PARTITION.
|
||
|
||
/** Для FETCH PARTITION - путь в ZK к шарду, с которого скачивать партицию.
|
||
*/
|
||
String from;
|
||
|
||
/** Для RESHARD PARTITION.
|
||
*/
|
||
ASTPtr last_partition;
|
||
ASTPtr weighted_zookeeper_paths;
|
||
ASTPtr sharding_key_expr;
|
||
ASTPtr coordinator;
|
||
|
||
/** For FREEZE PARTITION - place local backup to directory with specified name.
|
||
*/
|
||
String with_name;
|
||
|
||
/// deep copy
|
||
void clone(Parameters & p) const;
|
||
};
|
||
|
||
using ParameterContainer = std::vector<Parameters>;
|
||
ParameterContainer parameters;
|
||
String database;
|
||
String table;
|
||
|
||
|
||
void addParameters(const Parameters & params);
|
||
|
||
ASTAlterQuery(StringRange range_ = StringRange());
|
||
|
||
/** Получить текст, который идентифицирует этот элемент. */
|
||
String getID() const override;
|
||
|
||
ASTPtr clone() const override;
|
||
|
||
protected:
|
||
void formatImpl(const FormatSettings & settings, FormatState & state, FormatStateStacked frame) const override;
|
||
};
|
||
|
||
}
|