#pragma once #include #include #include #include #include #include namespace DB { /** Поток для вывода данных в формате JSON. */ class JSONRowOutputStream : public IRowOutputStream { public: JSONRowOutputStream(WriteBuffer & ostr_, const Block & sample_); void writeField(const Field & field) override; void writeFieldDelimiter() override; void writeRowStartDelimiter() override; void writeRowEndDelimiter() override; void writePrefix() override; void writeSuffix() override; void flush() override { ostr.next(); dst_ostr.next(); } void setRowsBeforeLimit(size_t rows_before_limit_) override { applied_limit = true; rows_before_limit = rows_before_limit_; } void setTotals(const Block & totals_) override { totals = totals_; } void setExtremes(const Block & extremes_) override { extremes = extremes_; } protected: void writeRowsBeforeLimitAtLeast(); virtual void writeTotals(); virtual void writeExtremes(); WriteBuffer & dst_ostr; WriteBufferValidUTF8 ostr; /// Валидирует и пишет в dst_ostr. size_t field_number; size_t row_count; bool applied_limit; size_t rows_before_limit; NamesAndTypes fields; Block totals; Block extremes; }; }