ClickHouse/dbms/src/DataStreams/BlockOutputStreamFromRowOutputStream.cpp
2012-05-08 11:38:00 +00:00

35 lines
753 B
C++

#include <DB/DataStreams/BlockOutputStreamFromRowOutputStream.h>
namespace DB
{
BlockOutputStreamFromRowOutputStream::BlockOutputStreamFromRowOutputStream(RowOutputStreamPtr row_output_)
: row_output(row_output_), first_row(true) {}
void BlockOutputStreamFromRowOutputStream::write(const Block & block)
{
size_t rows = block.rows();
size_t columns = block.columns();
for (size_t i = 0; i < rows; ++i)
{
if (!first_row)
row_output->writeRowBetweenDelimiter();
first_row = false;
row_output->writeRowStartDelimiter();
for (size_t j = 0; j < columns; ++j)
{
if (j != 0)
row_output->writeFieldDelimiter();
row_output->writeField((*block.getByPosition(j).column)[i]);
}
row_output->writeRowEndDelimiter();
}
}
}