#pragma once #include #include #include namespace DB { class MySQLDumpRowInputFormat final : public IRowInputFormat { public: MySQLDumpRowInputFormat(ReadBuffer & in_, const Block & header_, Params params_, const FormatSettings & format_settings_); String getName() const override { return "MySQLDumpRowInputFormat"; } void readPrefix() override; private: bool readRow(MutableColumns & columns, RowReadExtension &) override; bool readField(IColumn & column, size_t column_idx); void skipField(); bool supportsCountRows() const override { return true; } size_t countRows(size_t max_block_size) override; String table_name; DataTypes types; Block::NameMap column_indexes_by_names; const FormatSettings format_settings; }; class MySQLDumpSchemaReader : public IRowSchemaReader { public: MySQLDumpSchemaReader(ReadBuffer & in_, const FormatSettings & format_settings); private: NamesAndTypesList readSchema() override; std::optional readRowAndGetDataTypes() override; void transformTypesIfNeeded(DataTypePtr & type, DataTypePtr & new_type) override; String table_name; }; }