ClickHouse/dbms/src/Storages/MergeTree/MergeTreeDataPartWriterWide.h

83 lines
2.7 KiB
C++
Raw Normal View History

2019-10-21 00:28:29 +00:00
#include <Storages/MergeTree/IMergeTreeDataPartWriter.h>
namespace DB
{
2019-10-21 17:23:06 +00:00
class MergeTreeDataPartWriterWide : public IMergeTreeDataPartWriter
2019-10-21 00:28:29 +00:00
{
public:
2019-10-21 15:33:59 +00:00
using ColumnToSize = std::map<std::string, UInt64>;
MergeTreeDataPartWriterWide(
const String & part_path,
const MergeTreeData & storage,
const NamesAndTypesList & columns_list,
2019-11-07 11:11:38 +00:00
const std::vector<MergeTreeIndexPtr> & indices_to_recalc,
2019-10-21 15:33:59 +00:00
const String & marks_file_extension,
const CompressionCodecPtr & default_codec,
const WriterSettings & settings,
2019-11-07 11:11:38 +00:00
const MergeTreeIndexGranularity & index_granularity);
2019-10-21 15:33:59 +00:00
2019-11-07 11:11:38 +00:00
void write(const Block & block, const IColumn::Permutation * permutation,
const Block & primary_key_block = {}, const Block & skip_indexes_block = {}) override;
2019-10-21 00:28:29 +00:00
2019-11-05 11:53:22 +00:00
void finishDataSerialization(IMergeTreeDataPart::Checksums & checksums, bool write_final_mark, bool sync = false) override;
2019-10-21 17:23:06 +00:00
2019-10-21 00:28:29 +00:00
IDataType::OutputStreamGetter createStreamGetter(const String & name, WrittenOffsetColumns & offset_columns, bool skip_offsets);
/// Write data of one column.
/// Return how many marks were written and
/// how many rows were written for last mark
2019-10-22 17:42:59 +00:00
MarkWithOffset writeColumn(
2019-10-21 00:28:29 +00:00
const String & name,
const IDataType & type,
const IColumn & column,
WrittenOffsetColumns & offset_columns,
2019-11-07 11:11:38 +00:00
bool skip_offsets = false);
2019-10-21 00:28:29 +00:00
private:
/// Write single granule of one column (rows between 2 marks)
size_t writeSingleGranule(
const String & name,
const IDataType & type,
const IColumn & column,
WrittenOffsetColumns & offset_columns,
bool skip_offsets,
IDataType::SerializeBinaryBulkStatePtr & serialization_state,
IDataType::SerializeBinaryBulkSettings & serialize_settings,
size_t from_row,
size_t number_of_rows,
bool write_marks);
/// Write mark for column
void writeSingleMark(
const String & name,
const IDataType & type,
WrittenOffsetColumns & offset_columns,
bool skip_offsets,
size_t number_of_rows,
DB::IDataType::SubstreamPath & path);
2019-10-21 17:23:06 +00:00
void writeFinalMark(
const std::string & column_name,
const DataTypePtr column_type,
WrittenOffsetColumns & offset_columns,
bool skip_offsets,
DB::IDataType::SubstreamPath & path);
2019-10-21 00:28:29 +00:00
2019-10-21 15:33:59 +00:00
void addStreams(
const String & name,
const IDataType & type,
const CompressionCodecPtr & effective_codec,
size_t estimated_size,
bool skip_offsets);
2019-10-21 00:28:29 +00:00
SerializationStates serialization_states;
bool can_use_adaptive_granularity;
ColumnStreams column_streams;
};
2019-10-21 15:33:59 +00:00
}