#include #include #include #include #include #include #include #include #include namespace DB { ASTPtr processColumnTransformers( const String & current_database, const StoragePtr & table, const StorageMetadataPtr & metadata_snapshot, ASTPtr query_columns) { const auto & columns = metadata_snapshot->getColumns(); auto names_and_types = columns.getOrdinary(); removeDuplicateColumns(names_and_types); TablesWithColumns tables_with_columns; { auto table_expr = std::make_shared(); table_expr->database_and_table_name = std::make_shared(table->getStorageID()); table_expr->children.push_back(table_expr->database_and_table_name); tables_with_columns.emplace_back(DatabaseAndTableWithAlias(*table_expr, current_database), names_and_types); } tables_with_columns[0].addHiddenColumns(columns.getMaterialized()); tables_with_columns[0].addHiddenColumns(columns.getAliases()); tables_with_columns[0].addHiddenColumns(table->getVirtuals()); NameSet source_columns_set; for (const auto & identifier : query_columns->children) source_columns_set.insert(identifier->getColumnName()); TranslateQualifiedNamesVisitor::Data visitor_data(source_columns_set, tables_with_columns); TranslateQualifiedNamesVisitor visitor(visitor_data); auto columns_ast = query_columns->clone(); visitor.visit(columns_ast); return columns_ast; } }