#pragma once #include #include #include namespace DB { class WriteBuffer; class Context; /** Stream to output data in format "each value in separate row". * Usable to show few rows with many columns. */ class VerticalRowOutputFormat : public IRowOutputFormat { public: VerticalRowOutputFormat(WriteBuffer & out_, const Block & header_, FormatFactory::WriteCallback callback, const FormatSettings & format_settings_); String getName() const override { return "VerticalRowOutputFormat"; } void writeField(const IColumn & column, const IDataType & type, size_t row_num) override; void writeRowStartDelimiter() override; void writeRowBetweenDelimiter() override; void writeSuffix() override; void writeMinExtreme(const Columns & columns, size_t row_num) override; void writeMaxExtreme(const Columns & columns, size_t row_num) override; void writeTotals(const Columns & columns, size_t row_num) override; void writeBeforeTotals() override; void writeBeforeExtremes() override; protected: virtual void writeValue(const IColumn & column, const IDataType & type, size_t row_num) const; /// For totals and extremes. void writeSpecialRow(const Columns & columns, size_t row_num, PortKind port_kind, const char * title); const FormatSettings format_settings; size_t field_number = 0; size_t row_number = 0; bool was_totals_written = false; using NamesAndPaddings = std::vector; NamesAndPaddings names_and_paddings; }; }