#include "StorageSystemProjectionParts.h" #include #include #include #include #include #include #include #include #include #include #include #include namespace DB { StorageSystemProjectionParts::StorageSystemProjectionParts(const StorageID & table_id_) : StorageSystemPartsBase(table_id_, { {"partition", std::make_shared()}, {"name", std::make_shared()}, {"part_type", std::make_shared()}, {"parent_name", std::make_shared()}, {"parent_uuid", std::make_shared()}, {"parent_part_type", std::make_shared()}, {"active", std::make_shared()}, {"marks", std::make_shared()}, {"rows", std::make_shared()}, {"bytes_on_disk", std::make_shared()}, {"data_compressed_bytes", std::make_shared()}, {"data_uncompressed_bytes", std::make_shared()}, {"marks_bytes", std::make_shared()}, {"parent_marks", std::make_shared()}, {"parent_rows", std::make_shared()}, {"parent_bytes_on_disk", std::make_shared()}, {"parent_data_compressed_bytes", std::make_shared()}, {"parent_data_uncompressed_bytes", std::make_shared()}, {"parent_marks_bytes", std::make_shared()}, {"modification_time", std::make_shared()}, {"remove_time", std::make_shared()}, {"refcount", std::make_shared()}, {"min_date", std::make_shared()}, {"max_date", std::make_shared()}, {"min_time", std::make_shared()}, {"max_time", std::make_shared()}, {"partition_id", std::make_shared()}, {"min_block_number", std::make_shared()}, {"max_block_number", std::make_shared()}, {"level", std::make_shared()}, {"data_version", std::make_shared()}, {"primary_key_bytes_in_memory", std::make_shared()}, {"primary_key_bytes_in_memory_allocated", std::make_shared()}, {"is_frozen", std::make_shared()}, {"database", std::make_shared()}, {"table", std::make_shared()}, {"engine", std::make_shared()}, {"disk_name", std::make_shared()}, {"path", std::make_shared()}, {"hash_of_all_files", std::make_shared()}, {"hash_of_uncompressed_files", std::make_shared()}, {"uncompressed_hash_of_compressed_files", std::make_shared()}, {"delete_ttl_info_min", std::make_shared()}, {"delete_ttl_info_max", std::make_shared()}, {"move_ttl_info.expression", std::make_shared(std::make_shared())}, {"move_ttl_info.min", std::make_shared(std::make_shared())}, {"move_ttl_info.max", std::make_shared(std::make_shared())}, {"default_compression_codec", std::make_shared()}, {"recompression_ttl_info.expression", std::make_shared(std::make_shared())}, {"recompression_ttl_info.min", std::make_shared(std::make_shared())}, {"recompression_ttl_info.max", std::make_shared(std::make_shared())}, {"group_by_ttl_info.expression", std::make_shared(std::make_shared())}, {"group_by_ttl_info.min", std::make_shared(std::make_shared())}, {"group_by_ttl_info.max", std::make_shared(std::make_shared())}, {"rows_where_ttl_info.expression", std::make_shared(std::make_shared())}, {"rows_where_ttl_info.min", std::make_shared(std::make_shared())}, {"rows_where_ttl_info.max", std::make_shared(std::make_shared())} } ) { } void StorageSystemProjectionParts::processNextStorage( ContextPtr, MutableColumns & columns, std::vector & columns_mask, const StoragesInfo & info, bool has_state_column) { using State = MergeTreeDataPartState; MergeTreeData::DataPartStateVector all_parts_state; MergeTreeData::ProjectionPartsVector all_parts = info.getProjectionParts(all_parts_state, has_state_column); for (size_t part_number = 0; part_number < all_parts.projection_parts.size(); ++part_number) { const auto & part = all_parts.projection_parts[part_number]; const auto * parent_part = part->getParentPart(); chassert(parent_part); auto part_state = all_parts_state[part_number]; ColumnSize columns_size = part->getTotalColumnsSize(); ColumnSize parent_columns_size = parent_part->getTotalColumnsSize(); size_t src_index = 0, res_index = 0; if (columns_mask[src_index++]) { WriteBufferFromOwnString out; parent_part->partition.serializeText(*info.data, out, format_settings); columns[res_index++]->insert(out.str()); } if (columns_mask[src_index++]) columns[res_index++]->insert(part->name); if (columns_mask[src_index++]) columns[res_index++]->insert(part->getTypeName()); if (columns_mask[src_index++]) columns[res_index++]->insert(parent_part->name); if (columns_mask[src_index++]) columns[res_index++]->insert(parent_part->uuid); if (columns_mask[src_index++]) columns[res_index++]->insert(parent_part->getTypeName()); if (columns_mask[src_index++]) columns[res_index++]->insert(part_state == State::Active); if (columns_mask[src_index++]) columns[res_index++]->insert(part->getMarksCount()); if (columns_mask[src_index++]) columns[res_index++]->insert(part->rows_count); if (columns_mask[src_index++]) columns[res_index++]->insert(part->getBytesOnDisk()); if (columns_mask[src_index++]) columns[res_index++]->insert(columns_size.data_compressed); if (columns_mask[src_index++]) columns[res_index++]->insert(columns_size.data_uncompressed); if (columns_mask[src_index++]) columns[res_index++]->insert(columns_size.marks); if (columns_mask[src_index++]) columns[res_index++]->insert(parent_part->getMarksCount()); if (columns_mask[src_index++]) columns[res_index++]->insert(parent_part->rows_count); if (columns_mask[src_index++]) columns[res_index++]->insert(parent_part->getBytesOnDisk()); if (columns_mask[src_index++]) columns[res_index++]->insert(parent_columns_size.data_compressed); if (columns_mask[src_index++]) columns[res_index++]->insert(parent_columns_size.data_uncompressed); if (columns_mask[src_index++]) columns[res_index++]->insert(parent_columns_size.marks); if (columns_mask[src_index++]) columns[res_index++]->insert(static_cast(part->modification_time)); if (columns_mask[src_index++]) { time_t remove_time = part->remove_time.load(std::memory_order_relaxed); columns[res_index++]->insert(static_cast(remove_time == std::numeric_limits::max() ? 0 : remove_time)); } /// For convenience, in returned refcount, don't add references that was due to local variables in this method: all_parts, active_parts. if (columns_mask[src_index++]) columns[res_index++]->insert(static_cast(part.use_count() - 1)); auto min_max_date = parent_part->getMinMaxDate(); auto min_max_time = parent_part->getMinMaxTime(); if (columns_mask[src_index++]) columns[res_index++]->insert(min_max_date.first); if (columns_mask[src_index++]) columns[res_index++]->insert(min_max_date.second); if (columns_mask[src_index++]) columns[res_index++]->insert(static_cast(min_max_time.first)); if (columns_mask[src_index++]) columns[res_index++]->insert(static_cast(min_max_time.second)); if (columns_mask[src_index++]) columns[res_index++]->insert(parent_part->info.partition_id); if (columns_mask[src_index++]) columns[res_index++]->insert(parent_part->info.min_block); if (columns_mask[src_index++]) columns[res_index++]->insert(parent_part->info.max_block); if (columns_mask[src_index++]) columns[res_index++]->insert(parent_part->info.level); if (columns_mask[src_index++]) columns[res_index++]->insert(static_cast(parent_part->info.getDataVersion())); if (columns_mask[src_index++]) columns[res_index++]->insert(part->getIndexSizeInBytes()); if (columns_mask[src_index++]) columns[res_index++]->insert(part->getIndexSizeInAllocatedBytes()); if (columns_mask[src_index++]) columns[res_index++]->insert(part->is_frozen.load(std::memory_order_relaxed)); if (columns_mask[src_index++]) columns[res_index++]->insert(info.database); if (columns_mask[src_index++]) columns[res_index++]->insert(info.table); if (columns_mask[src_index++]) columns[res_index++]->insert(info.engine); if (part->isStoredOnDisk()) { if (columns_mask[src_index++]) columns[res_index++]->insert(part->getDataPartStorage().getDiskName()); if (columns_mask[src_index++]) columns[res_index++]->insert(part->getDataPartStorage().getFullPath()); } else { if (columns_mask[src_index++]) columns[res_index++]->insertDefault(); if (columns_mask[src_index++]) columns[res_index++]->insertDefault(); } { MinimalisticDataPartChecksums helper; if (columns_mask[src_index] || columns_mask[src_index + 1] || columns_mask[src_index + 2]) helper.computeTotalChecksums(part->checksums); if (columns_mask[src_index++]) { auto checksum = helper.hash_of_all_files; columns[res_index++]->insert(getHexUIntLowercase(checksum.first) + getHexUIntLowercase(checksum.second)); } if (columns_mask[src_index++]) { auto checksum = helper.hash_of_uncompressed_files; columns[res_index++]->insert(getHexUIntLowercase(checksum.first) + getHexUIntLowercase(checksum.second)); } if (columns_mask[src_index++]) { auto checksum = helper.uncompressed_hash_of_compressed_files; columns[res_index++]->insert(getHexUIntLowercase(checksum.first) + getHexUIntLowercase(checksum.second)); } } /// delete_ttl_info if (columns_mask[src_index++]) columns[res_index++]->insert(static_cast(part->ttl_infos.table_ttl.min)); if (columns_mask[src_index++]) columns[res_index++]->insert(static_cast(part->ttl_infos.table_ttl.max)); auto add_ttl_info_map = [&](const TTLInfoMap & ttl_info_map) { Array expression_array; Array min_array; Array max_array; if (columns_mask[src_index]) expression_array.reserve(ttl_info_map.size()); if (columns_mask[src_index + 1]) min_array.reserve(ttl_info_map.size()); if (columns_mask[src_index + 2]) max_array.reserve(ttl_info_map.size()); for (const auto & [expression, ttl_info] : ttl_info_map) { if (columns_mask[src_index]) expression_array.emplace_back(expression); if (columns_mask[src_index + 1]) min_array.push_back(static_cast(ttl_info.min)); if (columns_mask[src_index + 2]) max_array.push_back(static_cast(ttl_info.max)); } if (columns_mask[src_index++]) columns[res_index++]->insert(expression_array); if (columns_mask[src_index++]) columns[res_index++]->insert(min_array); if (columns_mask[src_index++]) columns[res_index++]->insert(max_array); }; add_ttl_info_map(part->ttl_infos.moves_ttl); if (columns_mask[src_index++]) columns[res_index++]->insert(queryToString(part->default_codec->getCodecDesc())); add_ttl_info_map(part->ttl_infos.recompression_ttl); add_ttl_info_map(part->ttl_infos.group_by_ttl); add_ttl_info_map(part->ttl_infos.rows_where_ttl); /// _state column should be the latest. /// Do not use part->getState*, it can be changed from different thread if (has_state_column) columns[res_index++]->insert(IMergeTreeDataPart::stateString(part_state)); } } }