ClickHouse/dbms/Parsers/ASTKillQueryQuery.h

45 lines
1.2 KiB
C++
Raw Normal View History

#include <Parsers/IAST.h>
#include <Parsers/ASTQueryWithOutput.h>
#include <Parsers/ASTQueryWithOnCluster.h>
2016-11-30 17:31:05 +00:00
namespace DB
{
class ASTKillQueryQuery : public ASTQueryWithOutput, public ASTQueryWithOnCluster
2016-11-30 17:31:05 +00:00
{
public:
enum class Type
{
Query, /// KILL QUERY
Mutation, /// KILL MUTATION
};
Type type = Type::Query;
ASTPtr where_expression; // expression to filter processes from system.processes table
bool sync = false; // SYNC or ASYNC mode
bool test = false; // does it TEST mode? (doesn't cancel queries just checks and shows them)
2016-11-30 17:31:05 +00:00
ASTPtr clone() const override
{
auto clone = std::make_shared<ASTKillQueryQuery>(*this);
if (where_expression)
{
clone->where_expression = where_expression->clone();
clone->children = {clone->where_expression};
}
return clone;
}
2016-11-30 17:31:05 +00:00
String getID(char) const override;
2016-11-30 17:31:05 +00:00
void formatQueryImpl(const FormatSettings & settings, FormatState & state, FormatStateStacked frame) const override;
ASTPtr getRewrittenASTWithoutOnCluster(const std::string &) const override
{
return removeOnCluster<ASTKillQueryQuery>(clone());
}
2016-11-30 17:31:05 +00:00
};
}