ClickHouse/dbms/src/Storages/MutationCommands.h

44 lines
723 B
C++

#pragma once
#include <Parsers/ASTAlterQuery.h>
#include <optional>
namespace DB
{
class IStorage;
class Context;
class WriteBuffer;
class ReadBuffer;
struct MutationCommand
{
ASTPtr ast; /// The AST of the whole command
enum Type
{
EMPTY, /// Not used.
DELETE,
};
Type type = EMPTY;
ASTPtr predicate;
static std::optional<MutationCommand> parse(ASTAlterCommand * command);
};
class MutationCommands : public std::vector<MutationCommand>
{
public:
std::shared_ptr<ASTAlterCommandList> ast() const;
void validate(const IStorage & table, const Context & context) const;
void writeText(WriteBuffer & out) const;
void readText(ReadBuffer & in);
};
}