2011-10-31 17:30:44 +00:00
|
|
|
#pragma once
|
|
|
|
|
2019-04-03 11:13:22 +00:00
|
|
|
#include <Common/NamePrompter.h>
|
2019-05-17 14:34:25 +00:00
|
|
|
#include <Parsers/IAST_fwd.h>
|
2023-05-30 12:31:23 +00:00
|
|
|
#include <Parsers/ASTCreateQuery.h>
|
2019-05-17 14:34:25 +00:00
|
|
|
#include <Storages/ColumnsDescription.h>
|
2019-08-24 21:20:20 +00:00
|
|
|
#include <Storages/ConstraintsDescription.h>
|
2019-05-17 14:34:25 +00:00
|
|
|
#include <Storages/IStorage_fwd.h>
|
2019-12-15 06:34:43 +00:00
|
|
|
#include <Storages/registerStorages.h>
|
2021-10-31 08:51:20 +00:00
|
|
|
#include <Access/Common/AccessType.h>
|
2017-12-28 21:36:27 +00:00
|
|
|
#include <unordered_map>
|
2011-10-31 17:30:44 +00:00
|
|
|
|
|
|
|
|
|
|
|
namespace DB
|
|
|
|
{
|
|
|
|
|
2012-05-22 19:32:56 +00:00
|
|
|
class Context;
|
2019-12-04 16:06:55 +00:00
|
|
|
struct StorageID;
|
2011-10-31 17:30:44 +00:00
|
|
|
|
|
|
|
|
2017-12-30 00:36:06 +00:00
|
|
|
/** Allows to create a table by the name and parameters of the engine.
|
2018-03-06 20:18:34 +00:00
|
|
|
* In 'columns' Nested data structures must be flattened.
|
2017-06-06 17:06:14 +00:00
|
|
|
* You should subsequently call IStorage::startup method to work with table.
|
2011-10-31 17:30:44 +00:00
|
|
|
*/
|
2023-09-10 03:48:12 +00:00
|
|
|
class StorageFactory : private boost::noncopyable, public IHints<>
|
2011-10-31 17:30:44 +00:00
|
|
|
{
|
|
|
|
public:
|
2019-08-22 03:24:05 +00:00
|
|
|
|
|
|
|
static StorageFactory & instance();
|
|
|
|
|
2017-12-28 21:36:27 +00:00
|
|
|
struct Arguments
|
|
|
|
{
|
2017-12-30 00:36:06 +00:00
|
|
|
const String & engine_name;
|
2024-01-18 01:56:21 +00:00
|
|
|
/// Mutable to allow replacing constant expressions with literals, and other transformations.
|
2017-12-30 00:36:06 +00:00
|
|
|
ASTs & engine_args;
|
|
|
|
ASTStorage * storage_def;
|
|
|
|
const ASTCreateQuery & query;
|
2019-10-25 19:07:47 +00:00
|
|
|
/// Path to table data.
|
|
|
|
/// Relative to <path> from server config (possibly <path> of some <disk> of some <volume> for *MergeTree)
|
|
|
|
const String & relative_data_path;
|
2019-12-04 16:06:55 +00:00
|
|
|
const StorageID & table_id;
|
2021-05-31 14:49:02 +00:00
|
|
|
ContextWeakMutablePtr local_context;
|
|
|
|
ContextWeakMutablePtr context;
|
2018-03-06 20:18:34 +00:00
|
|
|
const ColumnsDescription & columns;
|
2019-08-24 21:20:20 +00:00
|
|
|
const ConstraintsDescription & constraints;
|
2017-12-28 21:36:27 +00:00
|
|
|
bool attach;
|
|
|
|
bool has_force_restore_data_flag;
|
2021-04-23 12:18:23 +00:00
|
|
|
const String & comment;
|
2021-04-10 23:33:54 +00:00
|
|
|
|
2021-05-31 14:49:02 +00:00
|
|
|
ContextMutablePtr getContext() const;
|
|
|
|
ContextMutablePtr getLocalContext() const;
|
2017-12-28 21:36:27 +00:00
|
|
|
};
|
|
|
|
|
2021-01-08 11:36:42 +00:00
|
|
|
/// Analog of the IStorage::supports*() helpers
|
|
|
|
/// (But the former cannot be replaced with StorageFeatures due to nesting)
|
2020-01-25 19:14:33 +00:00
|
|
|
struct StorageFeatures
|
|
|
|
{
|
|
|
|
bool supports_settings = false;
|
|
|
|
bool supports_skipping_indices = false;
|
2021-02-10 14:12:49 +00:00
|
|
|
bool supports_projections = false;
|
2020-01-25 19:14:33 +00:00
|
|
|
bool supports_sort_order = false;
|
2022-01-11 01:58:53 +00:00
|
|
|
/// See also IStorage::supportsTTL()
|
2020-01-25 19:14:33 +00:00
|
|
|
bool supports_ttl = false;
|
2021-01-08 11:36:42 +00:00
|
|
|
/// See also IStorage::supportsReplication()
|
2020-01-27 14:14:49 +00:00
|
|
|
bool supports_replication = false;
|
2021-01-08 11:36:42 +00:00
|
|
|
/// See also IStorage::supportsDeduplication()
|
2020-01-27 14:14:49 +00:00
|
|
|
bool supports_deduplication = false;
|
2021-01-08 11:42:17 +00:00
|
|
|
/// See also IStorage::supportsParallelInsert()
|
|
|
|
bool supports_parallel_insert = false;
|
2021-12-15 11:30:57 +00:00
|
|
|
bool supports_schema_inference = false;
|
2020-04-06 05:19:40 +00:00
|
|
|
AccessType source_access_type = AccessType::NONE;
|
2020-01-25 19:14:33 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
using CreatorFn = std::function<StoragePtr(const Arguments & arguments)>;
|
|
|
|
struct Creator
|
|
|
|
{
|
|
|
|
CreatorFn creator_fn;
|
|
|
|
StorageFeatures features;
|
|
|
|
};
|
|
|
|
|
|
|
|
using Storages = std::unordered_map<std::string, Creator>;
|
2017-12-28 21:36:27 +00:00
|
|
|
|
2011-10-31 17:30:44 +00:00
|
|
|
StoragePtr get(
|
2019-12-16 18:10:35 +00:00
|
|
|
const ASTCreateQuery & query,
|
2019-10-25 19:07:47 +00:00
|
|
|
const String & relative_data_path,
|
2021-05-31 14:49:02 +00:00
|
|
|
ContextMutablePtr local_context,
|
|
|
|
ContextMutablePtr context,
|
2018-03-06 20:18:34 +00:00
|
|
|
const ColumnsDescription & columns,
|
2019-08-24 21:20:20 +00:00
|
|
|
const ConstraintsDescription & constraints,
|
2016-08-09 21:48:05 +00:00
|
|
|
bool has_force_restore_data_flag) const;
|
2017-12-28 21:36:27 +00:00
|
|
|
|
2017-12-30 04:03:30 +00:00
|
|
|
/// Register a table engine by its name.
|
|
|
|
/// No locking, you must register all engines before usage of get.
|
2020-01-25 19:14:33 +00:00
|
|
|
void registerStorage(const std::string & name, CreatorFn creator_fn, StorageFeatures features = StorageFeatures{
|
|
|
|
.supports_settings = false,
|
|
|
|
.supports_skipping_indices = false,
|
2021-02-10 14:12:49 +00:00
|
|
|
.supports_projections = false,
|
2020-01-25 19:14:33 +00:00
|
|
|
.supports_sort_order = false,
|
|
|
|
.supports_ttl = false,
|
2020-01-27 14:14:49 +00:00
|
|
|
.supports_replication = false,
|
|
|
|
.supports_deduplication = false,
|
2021-01-08 11:42:17 +00:00
|
|
|
.supports_parallel_insert = false,
|
2021-12-15 11:30:57 +00:00
|
|
|
.supports_schema_inference = false,
|
2020-04-06 05:19:40 +00:00
|
|
|
.source_access_type = AccessType::NONE,
|
2020-01-25 19:14:33 +00:00
|
|
|
});
|
2017-12-28 21:36:27 +00:00
|
|
|
|
2020-01-25 19:14:33 +00:00
|
|
|
const Storages & getAllStorages() const
|
2018-07-25 16:08:23 +00:00
|
|
|
{
|
|
|
|
return storages;
|
|
|
|
}
|
|
|
|
|
2019-04-03 11:13:22 +00:00
|
|
|
std::vector<String> getAllRegisteredNames() const override
|
|
|
|
{
|
|
|
|
std::vector<String> result;
|
|
|
|
auto getter = [](const auto & pair) { return pair.first; };
|
|
|
|
std::transform(storages.begin(), storages.end(), std::back_inserter(result), getter);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2020-01-25 19:14:33 +00:00
|
|
|
using FeatureMatcherFn = std::function<bool(StorageFeatures)>;
|
|
|
|
std::vector<String> getAllRegisteredNamesByFeatureMatcherFn(FeatureMatcherFn feature_matcher_fn) const
|
|
|
|
{
|
|
|
|
std::vector<String> result;
|
|
|
|
for (const auto& pair : storages)
|
|
|
|
if (feature_matcher_fn(pair.second.features))
|
|
|
|
result.push_back(pair.first);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2020-04-06 05:19:40 +00:00
|
|
|
AccessType getSourceAccessType(const String & table_engine) const;
|
2020-01-25 19:14:33 +00:00
|
|
|
|
2021-12-15 11:30:57 +00:00
|
|
|
bool checkIfStorageSupportsSchemaInterface(const String & storage_name)
|
|
|
|
{
|
|
|
|
if (storages.contains(storage_name))
|
|
|
|
return storages[storage_name].features.supports_schema_inference;
|
|
|
|
return false;
|
|
|
|
}
|
2017-12-28 21:36:27 +00:00
|
|
|
private:
|
|
|
|
Storages storages;
|
2011-10-31 17:30:44 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|