mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-01 20:12:02 +00:00
97f2a2213e
* Move some code outside dbms/src folder * Fix paths
57 lines
1.7 KiB
C++
57 lines
1.7 KiB
C++
#include <Storages/MergeTree/IMergeTreeDataPartWriter.h>
|
|
|
|
namespace DB
|
|
{
|
|
|
|
/// Writes data part in compact format.
|
|
class MergeTreeDataPartWriterCompact : public IMergeTreeDataPartWriter
|
|
{
|
|
public:
|
|
MergeTreeDataPartWriterCompact(
|
|
DiskPtr disk,
|
|
const String & part_path,
|
|
const MergeTreeData & storage,
|
|
const NamesAndTypesList & columns_list,
|
|
const std::vector<MergeTreeIndexPtr> & indices_to_recalc,
|
|
const String & marks_file_extension,
|
|
const CompressionCodecPtr & default_codec,
|
|
const MergeTreeWriterSettings & settings,
|
|
const MergeTreeIndexGranularity & index_granularity);
|
|
|
|
void write(const Block & block, const IColumn::Permutation * permutation,
|
|
const Block & primary_key_block, const Block & skip_indexes_block) override;
|
|
|
|
void finishDataSerialization(IMergeTreeDataPart::Checksums & checksums, bool sync) override;
|
|
|
|
private:
|
|
/// Write single granule of one column (rows between 2 marks)
|
|
void writeColumnSingleGranule(
|
|
const ColumnWithTypeAndName & column,
|
|
size_t from_row,
|
|
size_t number_of_rows) const;
|
|
|
|
void writeBlock(const Block & block);
|
|
|
|
StreamPtr stream;
|
|
|
|
Block header;
|
|
|
|
/** Simplified SquashingTransform. The original one isn't suitable in this case
|
|
* as it can return smaller block from buffer without merging it with larger block if last is enough size.
|
|
* But in compact parts we should guarantee, that written block is larger or equals than index_granularity.
|
|
*/
|
|
class ColumnsBuffer
|
|
{
|
|
public:
|
|
void add(MutableColumns && columns);
|
|
size_t size() const;
|
|
Columns releaseColumns();
|
|
private:
|
|
MutableColumns accumulated_columns;
|
|
};
|
|
|
|
ColumnsBuffer columns_buffer;
|
|
};
|
|
|
|
}
|