#pragma once #include #include #include #include #include namespace Poco { class Logger; } namespace DB { /* Database to store StorageDictionary tables * automatically creates tables for all dictionaries */ class DatabaseDictionary : public IDatabase { public: DatabaseDictionary(const String & name_); String getDatabaseName() const override; String getEngineName() const override { return "Dictionary"; } void loadTables( Context & context, ThreadPool * thread_pool, bool has_force_restore_data_flag) override; bool isTableExist( const Context & context, const String & table_name) const override; StoragePtr tryGetTable( const Context & context, const String & table_name) const override; DatabaseIteratorPtr getIterator(const Context & context) override; bool empty(const Context & context) const override; void createTable( const Context & context, const String & table_name, const StoragePtr & table, const ASTPtr & query) override; void removeTable( const Context & context, 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) override; void alterTable( const Context & context, const String & name, const ColumnsDescription & columns, const ASTModifier & engine_modifier) override; time_t getTableMetadataModificationTime( const Context & context, const String & table_name) override; ASTPtr getCreateTableQuery( const Context & context, const String & table_name) const override; ASTPtr tryGetCreateTableQuery( const Context & context, const String & table_name) const override; ASTPtr getCreateDatabaseQuery(const Context & context) const override; void shutdown() override; private: const String name; mutable std::mutex mutex; Poco::Logger * log; Tables listTables(const Context & context); ASTPtr getCreateTableQueryImpl(const Context & context, const String & table_name, bool throw_on_error) const; }; }