#pragma once #include namespace DB { /* Allow to compute more accurate progress statistics */ class ColumnSizeEstimator { using ColumnToSize = std::map; ColumnToSize map; public: /// Stores approximate size of columns in bytes /// Exact values are not required since it used for relative values estimation (progress). size_t sum_total = 0; size_t sum_index_columns = 0; size_t sum_ordinary_columns = 0; ColumnSizeEstimator(ColumnToSize && map_, const NamesAndTypesList & key_columns, const NamesAndTypesList & ordinary_columns) : map(std::move(map_)) { for (const auto & [name, _] : key_columns) if (!map.contains(name)) map[name] = 0; for (const auto & [name, _] : ordinary_columns) if (!map.contains(name)) map[name] = 0; for (const auto & [name, _] : key_columns) sum_index_columns += map.at(name); for (const auto & [name, _] : ordinary_columns) sum_ordinary_columns += map.at(name); sum_total = std::max(static_cast(1), sum_index_columns + sum_ordinary_columns); } Float64 columnWeight(const String & column) const { return static_cast(map.at(column)) / sum_total; } Float64 keyColumnsWeight() const { return static_cast(sum_index_columns) / sum_total; } }; }