mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-11-18 13:42:02 +00:00
45 lines
1.1 KiB
C++
45 lines
1.1 KiB
C++
#pragma once
|
|
|
|
#include <Interpreters/IInterpreter.h>
|
|
#include <Parsers/IAST_fwd.h>
|
|
#include <Storages/IStorage_fwd.h>
|
|
|
|
|
|
namespace Poco { class Logger; }
|
|
|
|
namespace DB
|
|
{
|
|
|
|
class Context;
|
|
class AccessRightsElements;
|
|
class ASTSystemQuery;
|
|
|
|
class InterpreterSystemQuery : public IInterpreter
|
|
{
|
|
public:
|
|
InterpreterSystemQuery(const ASTPtr & query_ptr_, Context & context_);
|
|
|
|
BlockIO execute() override;
|
|
|
|
bool ignoreQuota() const override { return true; }
|
|
bool ignoreLimits() const override { return true; }
|
|
|
|
private:
|
|
ASTPtr query_ptr;
|
|
Context & context;
|
|
Poco::Logger * log = nullptr;
|
|
|
|
/// Tries to get a replicated table and restart it
|
|
/// Returns pointer to a newly created table if the restart was successful
|
|
StoragePtr tryRestartReplica(const String & database_name, const String & table_name, Context & context);
|
|
|
|
void restartReplicas(Context & system_context);
|
|
void syncReplica(ASTSystemQuery & query);
|
|
void flushDistributed(ASTSystemQuery & query);
|
|
|
|
AccessRightsElements getRequiredAccessForDDLOnCluster() const;
|
|
};
|
|
|
|
|
|
}
|