#include "StorageSystemPartsColumns.h" #include #include #include #include #include #include #include #include #include namespace DB { StorageSystemPartsColumns::StorageSystemPartsColumns(const StorageID & table_id_) : StorageSystemPartsBase(table_id_, { {"partition", std::make_shared()}, {"name", std::make_shared()}, {"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()}, {"modification_time", std::make_shared()}, {"remove_time", std::make_shared()}, {"refcount", std::make_shared()}, {"min_date", std::make_shared()}, {"max_date", 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()}, {"database", std::make_shared()}, {"table", std::make_shared()}, {"engine", std::make_shared()}, {"disk_name", std::make_shared()}, {"path", std::make_shared()}, {"column", std::make_shared()}, {"type", std::make_shared()}, {"column_position", std::make_shared()}, {"default_kind", std::make_shared()}, {"default_expression", std::make_shared()}, {"column_bytes_on_disk", std::make_shared()}, {"column_data_compressed_bytes", std::make_shared()}, {"column_data_uncompressed_bytes", std::make_shared()}, {"column_marks_bytes", std::make_shared()} } ) { } void StorageSystemPartsColumns::processNextStorage( MutableColumns & columns, std::vector & columns_mask, const StoragesInfo & info, bool has_state_column) { /// Prepare information about columns in storage. struct ColumnInfo { String default_kind; String default_expression; }; std::unordered_map columns_info; for (const auto & column : info.storage->getInMemoryMetadataPtr()->getColumns()) { ColumnInfo column_info; if (column.default_desc.expression) { column_info.default_kind = toString(column.default_desc.kind); column_info.default_expression = queryToString(column.default_desc.expression); } columns_info[column.name] = column_info; } /// Go through the list of parts. MergeTreeData::DataPartStateVector all_parts_state; MergeTreeData::DataPartsVector all_parts; all_parts = info.getParts(all_parts_state, has_state_column); for (size_t part_number = 0; part_number < all_parts.size(); ++part_number) { const auto & part = all_parts[part_number]; auto part_state = all_parts_state[part_number]; auto columns_size = part->getTotalColumnsSize(); /// For convenience, in returned refcount, don't add references that was due to local variables in this method: all_parts, active_parts. auto use_count = part.use_count() - 1; auto min_date = part->getMinDate(); auto max_date = part->getMaxDate(); auto index_size_in_bytes = part->getIndexSizeInBytes(); auto index_size_in_allocated_bytes = part->getIndexSizeInAllocatedBytes(); using State = IMergeTreeDataPart::State; size_t column_position = 0; for (const auto & column : part->getColumns()) { ++column_position; size_t src_index = 0, res_index = 0; if (columns_mask[src_index++]) { WriteBufferFromOwnString out; 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(part_state == State::Committed); 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(UInt64(part->modification_time)); if (columns_mask[src_index++]) columns[res_index++]->insert(UInt64(part->remove_time.load(std::memory_order_relaxed))); if (columns_mask[src_index++]) columns[res_index++]->insert(UInt64(use_count)); if (columns_mask[src_index++]) columns[res_index++]->insert(min_date); if (columns_mask[src_index++]) columns[res_index++]->insert(max_date); if (columns_mask[src_index++]) columns[res_index++]->insert(part->info.partition_id); if (columns_mask[src_index++]) columns[res_index++]->insert(part->info.min_block); if (columns_mask[src_index++]) columns[res_index++]->insert(part->info.max_block); if (columns_mask[src_index++]) columns[res_index++]->insert(part->info.level); if (columns_mask[src_index++]) columns[res_index++]->insert(UInt64(part->info.getDataVersion())); if (columns_mask[src_index++]) columns[res_index++]->insert(index_size_in_bytes); if (columns_mask[src_index++]) columns[res_index++]->insert(index_size_in_allocated_bytes); 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 (columns_mask[src_index++]) columns[res_index++]->insert(part->volume->getDisk()->getName()); if (columns_mask[src_index++]) columns[res_index++]->insert(part->getFullPath()); if (columns_mask[src_index++]) columns[res_index++]->insert(column.name); if (columns_mask[src_index++]) columns[res_index++]->insert(column.type->getName()); if (columns_mask[src_index++]) columns[res_index++]->insert(column_position); auto column_info_it = columns_info.find(column.name); if (column_info_it != columns_info.end()) { if (columns_mask[src_index++]) columns[res_index++]->insert(column_info_it->second.default_kind); if (columns_mask[src_index++]) columns[res_index++]->insert(column_info_it->second.default_expression); } else { if (columns_mask[src_index++]) columns[res_index++]->insertDefault(); if (columns_mask[src_index++]) columns[res_index++]->insertDefault(); } ColumnSize column_size = part->getColumnSize(column.name, *column.type); if (columns_mask[src_index++]) columns[res_index++]->insert(column_size.data_compressed + column_size.marks); if (columns_mask[src_index++]) columns[res_index++]->insert(column_size.data_compressed); if (columns_mask[src_index++]) columns[res_index++]->insert(column_size.data_uncompressed); if (columns_mask[src_index++]) columns[res_index++]->insert(column_size.marks); if (has_state_column) columns[res_index++]->insert(part->stateString()); } } } }