2017-06-22 15:44:19 +00:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <mutex>
|
2017-06-23 15:55:45 +00:00
|
|
|
#include <unordered_set>
|
|
|
|
#include <Databases/DatabasesCommon.h>
|
2017-06-22 15:44:19 +00:00
|
|
|
#include <Databases/IDatabase.h>
|
|
|
|
#include <Storages/IStorage.h>
|
|
|
|
|
|
|
|
|
2017-06-23 15:55:45 +00:00
|
|
|
namespace Poco
|
|
|
|
{
|
2017-06-22 18:00:29 +00:00
|
|
|
class Logger;
|
2017-06-22 15:44:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
namespace DB
|
|
|
|
{
|
2017-06-23 15:55:45 +00:00
|
|
|
class ExternalDictionaries;
|
2017-06-22 15:44:19 +00:00
|
|
|
|
|
|
|
/* Database to store StorageDictionary tables
|
|
|
|
* automatically creates tables for all dictionaries
|
|
|
|
*/
|
|
|
|
class DatabaseDictionary : public IDatabase
|
|
|
|
{
|
2017-06-23 15:55:45 +00:00
|
|
|
private:
|
2017-06-22 15:44:19 +00:00
|
|
|
const String name;
|
|
|
|
mutable std::mutex mutex;
|
2017-06-23 15:55:45 +00:00
|
|
|
const ExternalDictionaries & external_dictionaries;
|
|
|
|
std::unordered_set<String> deleted_tables;
|
2017-06-22 15:44:19 +00:00
|
|
|
|
|
|
|
Poco::Logger * log;
|
|
|
|
|
2017-06-23 15:55:45 +00:00
|
|
|
Tables loadTables();
|
2017-06-22 15:44:19 +00:00
|
|
|
|
2017-06-23 15:55:45 +00:00
|
|
|
public:
|
|
|
|
DatabaseDictionary(const String & name_, const Context & context);
|
2017-06-22 15:44:19 +00:00
|
|
|
|
2017-06-22 18:00:29 +00:00
|
|
|
String getEngineName() const override
|
|
|
|
{
|
2017-06-22 15:44:19 +00:00
|
|
|
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;
|
|
|
|
|
2017-06-23 15:55:45 +00:00
|
|
|
void createTable(const String & table_name,
|
|
|
|
const StoragePtr & table,
|
|
|
|
const ASTPtr & query,
|
|
|
|
const String & engine,
|
|
|
|
const Settings & settings) override;
|
2017-06-22 15:44:19 +00:00
|
|
|
|
|
|
|
void removeTable(const String & table_name) override;
|
|
|
|
|
|
|
|
void attachTable(const String & table_name, const StoragePtr & table) override;
|
|
|
|
StoragePtr detachTable(const String & table_name) override;
|
|
|
|
|
2017-06-23 15:55:45 +00:00
|
|
|
void renameTable(const Context & context,
|
|
|
|
const String & table_name,
|
|
|
|
IDatabase & to_database,
|
|
|
|
const String & to_table_name,
|
|
|
|
const Settings & settings) override;
|
2017-06-22 15:44:19 +00:00
|
|
|
|
|
|
|
time_t getTableMetadataModificationTime(const String & table_name) override;
|
|
|
|
|
|
|
|
ASTPtr getCreateQuery(const String & table_name) const override;
|
|
|
|
|
|
|
|
void shutdown() override;
|
|
|
|
void drop() override;
|
|
|
|
|
2017-06-23 15:55:45 +00:00
|
|
|
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;
|
2017-06-22 15:44:19 +00:00
|
|
|
};
|
|
|
|
}
|