#pragma once #include #include #include #include #include namespace Poco { class Logger; } namespace DB { class ExternalDictionaries; /* Database to store StorageDictionary tables * automatically creates tables for all dictionaries */ class DatabaseDictionary : public IDatabase { private: const String name; mutable std::mutex mutex; const ExternalDictionaries & external_dictionaries; std::unordered_set deleted_tables; Poco::Logger * log; Tables loadTables(); public: DatabaseDictionary(const String & name_, const Context & context); String getEngineName() const override { return "Dictionary"; } void loadTables(Context & context, ThreadPool * thread_pool, bool has_force_restore_data_flag) override; bool isTableExist(const String & table_name) const override; StoragePtr tryGetTable(const String & table_name) override; DatabaseIteratorPtr getIterator() override; bool empty() const override; void createTable(const String & table_name, const StoragePtr & table, const ASTPtr & query, const String & engine, const Settings & settings) override; void removeTable(const String & table_name) override; void attachTable(const String & table_name, const StoragePtr & table) override; StoragePtr detachTable(const String & table_name) override; void renameTable(const Context & context, const String & table_name, IDatabase & to_database, const String & to_table_name, const Settings & settings) override; time_t getTableMetadataModificationTime(const String & table_name) override; ASTPtr getCreateQuery(const String & table_name) const override; void shutdown() override; void drop() override; void alterTable(const Context & context, const String & name, const NamesAndTypesList & columns, const NamesAndTypesList & materialized_columns, const NamesAndTypesList & alias_columns, const ColumnDefaults & column_defaults, const ASTModifier & engine_modifier) override; }; }