2021-07-18 14:42:41 +00:00
|
|
|
#pragma once
|
|
|
|
|
2021-07-22 21:27:26 +00:00
|
|
|
#include <Client/ClientBase.h>
|
2021-07-18 14:42:41 +00:00
|
|
|
#include <Core/ExternalTable.h>
|
|
|
|
|
|
|
|
|
|
|
|
namespace DB
|
|
|
|
{
|
|
|
|
|
2021-07-22 21:27:26 +00:00
|
|
|
class Client : public ClientBase
|
2021-07-18 14:42:41 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
Client() = default;
|
|
|
|
|
2021-07-23 20:56:47 +00:00
|
|
|
void initialize(Poco::Util::Application & self) override;
|
|
|
|
|
2021-07-18 14:42:41 +00:00
|
|
|
protected:
|
2021-07-28 12:56:11 +00:00
|
|
|
void processSingleQuery(const String & full_query) override;
|
2021-07-18 14:42:41 +00:00
|
|
|
|
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-18 14:42:41 +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
|
|
|
|
2021-07-29 09:45:09 +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-22 19:38:37 +00:00
|
|
|
|
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;
|
2021-07-18 14:42:41 +00:00
|
|
|
|
|
|
|
void readArguments(int argc, char ** argv,
|
|
|
|
Arguments & common_arguments,
|
|
|
|
std::vector<Arguments> & external_tables_arguments) override;
|
2021-07-28 12:56:11 +00:00
|
|
|
|
2021-07-18 14:42:41 +00:00
|
|
|
void printHelpMessage(const OptionsDescription & options_description) override;
|
2021-07-28 12:56:11 +00:00
|
|
|
|
2021-07-18 14:42:41 +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;
|
|
|
|
|
2021-07-18 14:42:41 +00:00
|
|
|
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-18 14:42:41 +00:00
|
|
|
|
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-18 14:42:41 +00:00
|
|
|
|
2021-07-28 12:56:11 +00:00
|
|
|
void sendData(Block & sample, const ColumnsDescription & columns_description, ASTPtr parsed_query);
|
2021-07-18 14:42:41 +00:00
|
|
|
void sendDataFrom(ReadBuffer & buf, Block & sample,
|
2021-07-28 12:56:11 +00:00
|
|
|
const ColumnsDescription & columns_description, ASTPtr parsed_query);
|
2021-07-18 14:42:41 +00:00
|
|
|
|
2021-07-28 12:56:11 +00:00
|
|
|
void receiveResult(ASTPtr parsed_query);
|
|
|
|
void receiveLogs(ASTPtr parsed_query);
|
2021-07-18 14:42:41 +00:00
|
|
|
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-18 14:42:41 +00:00
|
|
|
|
2021-07-28 12:56:11 +00:00
|
|
|
void initBlockOutputStream(const Block & block, ASTPtr parsed_query);
|
2021-07-18 14:42:41 +00:00
|
|
|
void initLogsOutputStream();
|
|
|
|
|
2021-07-28 12:56:11 +00:00
|
|
|
void onData(Block & block, ASTPtr parsed_query);
|
2021-07-18 14:42:41 +00:00
|
|
|
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);
|
2021-07-18 14:42:41 +00:00
|
|
|
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();
|
|
|
|
}
|
|
|
|
|
2021-07-18 14:42:41 +00:00
|
|
|
};
|
|
|
|
}
|