ClickHouse/dbms/include/DB/DataStreams/NativeBlockOutputStream.h

32 lines
1.1 KiB
C
Raw Normal View History

2011-08-19 19:18:15 +00:00
#pragma once
#include <DB/DataStreams/IBlockOutputStream.h>
namespace DB
{
/** Сериализует поток блоков в родном бинарном формате (с именами и типами столбцов).
* Предназначено для взаимодействия между серверами.
*/
class NativeBlockOutputStream : public IBlockOutputStream
{
public:
/** В случае указания ненулевой client_revision, может записываться дополнительная информация о блоке,
* в зависимости от поддерживаемой для указанной ревизии.
*/
NativeBlockOutputStream(WriteBuffer & ostr_, UInt64 client_revision_ = 0)
: ostr(ostr_), client_revision(client_revision_) {}
2011-08-19 19:18:15 +00:00
void write(const Block & block) override;
void flush() override { ostr.next(); }
static void writeData(const IDataType & type, const ColumnPtr & column, WriteBuffer & ostr, size_t offset, size_t limit);
2011-08-19 19:18:15 +00:00
private:
WriteBuffer & ostr;
UInt64 client_revision;
2011-08-19 19:18:15 +00:00
};
}