ClickHouse/programs/client/Client.h

113 lines
3.7 KiB
C++
Raw Normal View History

#pragma once
2021-07-22 21:27:26 +00:00
#include <Client/ClientBase.h>
#include <Core/ExternalTable.h>
namespace DB
{
2021-07-22 21:27:26 +00:00
class Client : public ClientBase
{
public:
Client() = default;
2021-07-23 20:56:47 +00:00
void initialize(Poco::Util::Application & self) override;
protected:
2021-07-28 12:56:11 +00:00
void processSingleQuery(const String & full_query) override;
2021-07-26 22:28:27 +00:00
bool processMultiQuery(const String & all_queries_text) override;
2021-07-28 12:56:11 +00:00
bool processWithFuzzing(const String & full_query) override;
2021-07-26 22:28:27 +00:00
2021-07-28 12:56:11 +00:00
void reportQueryError(const String & query) const override;
2021-07-26 22:28:27 +00:00
void executeSingleQuery(const String & query_to_execute, ASTPtr parsed_query) override;
2021-07-28 12:56:11 +00:00
void loadSuggestionData() override;
2021-07-23 20:54:49 +00:00
2021-07-28 12:56:11 +00:00
bool validateParsedOptions() override { return true; }
2021-07-23 20:56:47 +00:00
2021-07-28 12:56:11 +00:00
int mainImpl() override;
void readArguments(int argc, char ** argv,
Arguments & common_arguments,
std::vector<Arguments> & external_tables_arguments) override;
2021-07-28 12:56:11 +00:00
void printHelpMessage(const OptionsDescription & options_description) override;
2021-07-28 12:56:11 +00:00
void addOptions(OptionsDescription & options_description) override;
void processOptions(const OptionsDescription & options_description,
const CommandLineOptions & options,
const std::vector<Arguments> & external_tables_arguments) override;
2021-07-22 21:27:26 +00:00
void processConfig() override;
private:
std::unique_ptr<Connection> connection; /// Connection to DB.
String format; /// Query results output format.
bool is_default_format = true; /// false, if format is set in the config or command line.
size_t format_max_block_size = 0; /// Max block size for console output.
String insert_format; /// Format of INSERT data that is read from stdin in batch mode.
size_t insert_format_max_block_size = 0; /// Max block size when reading INSERT data.
size_t max_client_network_bandwidth = 0; /// The maximum speed of data exchange over the network for the client in bytes per second.
UInt64 server_revision = 0;
String server_version;
/// External tables info.
std::list<ExternalTable> external_tables;
/// Dictionary with query parameters for prepared statements.
NameToNameMap query_parameters;
ConnectionParameters connection_parameters;
void connect();
void printChangedSettings() const;
2021-07-28 12:56:11 +00:00
void sendExternalTables(ASTPtr parsed_query);
2021-07-28 12:56:11 +00:00
void processInsertQuery(const String & query_to_execute, ASTPtr parsed_query);
void processOrdinaryQuery(const String & query_to_execute, ASTPtr parsed_query);
2021-07-28 12:56:11 +00:00
void sendData(Block & sample, const ColumnsDescription & columns_description, ASTPtr parsed_query);
void sendDataFrom(ReadBuffer & buf, Block & sample,
2021-07-28 12:56:11 +00:00
const ColumnsDescription & columns_description, ASTPtr parsed_query);
2021-07-28 12:56:11 +00:00
void receiveResult(ASTPtr parsed_query);
void receiveLogs(ASTPtr parsed_query);
bool receiveEndOfQuery();
2021-07-28 12:56:11 +00:00
bool receiveAndProcessPacket(ASTPtr parsed_query, bool cancelled);
bool receiveSampleBlock(Block & out, ColumnsDescription & columns_description, ASTPtr parsed_query);
2021-07-28 12:56:11 +00:00
void initBlockOutputStream(const Block & block, ASTPtr parsed_query);
void initLogsOutputStream();
2021-07-28 12:56:11 +00:00
void onData(Block & block, ASTPtr parsed_query);
void onLogData(Block & block);
2021-07-28 12:56:11 +00:00
void onTotals(Block & block, ASTPtr parsed_query);
void onExtremes(Block & block, ASTPtr parsed_query);
void onProgress(const Progress & value);
void writeFinalProgress();
void onReceiveExceptionFromServer(std::unique_ptr<Exception> && e);
void onProfileInfo(const BlockStreamProfileInfo & profile_info);
void onEndOfStream();
2021-07-28 12:56:11 +00:00
std::vector<String> loadWarningMessages();
void reconnectIfNeeded() override
{
if (!connection->checkConnected())
connect();
}
};
}