#pragma once #include #include #include namespace DB { /** Таблица, представляющая собой объединение произвольного количества других таблиц. * У всех таблиц должна быть одинаковая структура. */ class StorageMerge : public IStorage { public: StorageMerge( const std::string & name_, /// Имя таблицы. NamesAndTypesListPtr columns_, /// Список столбцов. const String & source_database_, /// В какой БД искать таблицы-источники. const String & table_name_regexp_, /// Регексп имён таблиц-источников. Context & context_); /// Известные таблицы. std::string getName() const { return "Merge"; } std::string getTableName() const { return name; } bool supportsSampling() const { return true; } const NamesAndTypesList & getColumnsList() const { return *columns; } BlockInputStreams read( const Names & column_names, ASTPtr query, QueryProcessingStage::Enum & processed_stage, size_t max_block_size = DEFAULT_BLOCK_SIZE, unsigned threads = 1); void drop() {} void rename(const String & new_path_to_db, const String & new_name) { name = new_name; } private: String name; NamesAndTypesListPtr columns; String source_database; OptimizedRegularExpression table_name_regexp; Context context; }; }