mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-16 19:32:07 +00:00
97f2a2213e
* Move some code outside dbms/src folder * Fix paths
74 lines
2.3 KiB
C++
74 lines
2.3 KiB
C++
#include <Storages/MergeTree/MergeTreeIndices.h>
|
|
#include <Parsers/parseQuery.h>
|
|
#include <Parsers/ParserCreateQuery.h>
|
|
#include <IO/WriteHelpers.h>
|
|
#include <IO/ReadHelpers.h>
|
|
|
|
#include <numeric>
|
|
|
|
#include <boost/algorithm/string.hpp>
|
|
|
|
|
|
namespace DB
|
|
{
|
|
|
|
namespace ErrorCodes
|
|
{
|
|
extern const int LOGICAL_ERROR;
|
|
extern const int INCORRECT_QUERY;
|
|
}
|
|
|
|
void MergeTreeIndexFactory::registerIndex(const std::string & name, Creator creator)
|
|
{
|
|
if (!indexes.emplace(name, std::move(creator)).second)
|
|
throw Exception("MergeTreeIndexFactory: the Index creator name '" + name + "' is not unique",
|
|
ErrorCodes::LOGICAL_ERROR);
|
|
}
|
|
|
|
std::unique_ptr<IMergeTreeIndex> MergeTreeIndexFactory::get(
|
|
const NamesAndTypesList & columns,
|
|
std::shared_ptr<ASTIndexDeclaration> node,
|
|
const Context & context) const
|
|
{
|
|
if (!node->type)
|
|
throw Exception(
|
|
"for index TYPE is required", ErrorCodes::INCORRECT_QUERY);
|
|
if (node->type->parameters && !node->type->parameters->children.empty())
|
|
throw Exception(
|
|
"Index type can not have parameters", ErrorCodes::INCORRECT_QUERY);
|
|
|
|
boost::algorithm::to_lower(node->type->name);
|
|
auto it = indexes.find(node->type->name);
|
|
if (it == indexes.end())
|
|
throw Exception(
|
|
"Unknown Index type '" + node->type->name + "'. Available index types: " +
|
|
std::accumulate(indexes.cbegin(), indexes.cend(), std::string{},
|
|
[] (auto && left, const auto & right) -> std::string
|
|
{
|
|
if (left.empty())
|
|
return right.first;
|
|
else
|
|
return left + ", " + right.first;
|
|
}),
|
|
ErrorCodes::INCORRECT_QUERY);
|
|
|
|
return it->second(columns, node, context);
|
|
}
|
|
|
|
MergeTreeIndexFactory::MergeTreeIndexFactory()
|
|
{
|
|
registerIndex("minmax", minmaxIndexCreator);
|
|
registerIndex("set", setIndexCreator);
|
|
registerIndex("ngrambf_v1", bloomFilterIndexCreator);
|
|
registerIndex("tokenbf_v1", bloomFilterIndexCreator);
|
|
registerIndex("bloom_filter", bloomFilterIndexCreatorNew);
|
|
}
|
|
|
|
MergeTreeIndexFactory & MergeTreeIndexFactory::instance()
|
|
{
|
|
static MergeTreeIndexFactory instance;
|
|
return instance;
|
|
}
|
|
|
|
}
|