mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-14 10:22:10 +00:00
54 lines
1.8 KiB
C++
54 lines
1.8 KiB
C++
#include <AggregateFunctions/AggregateFunctionFactory.h>
|
|
#include <DataTypes/DataTypeString.h>
|
|
#include <DataTypes/DataTypesNumber.h>
|
|
#include <Functions/FunctionFactory.h>
|
|
#include <Functions/IFunction.h>
|
|
#include <Interpreters/Context.h>
|
|
#include <Storages/System/StorageSystemFunctions.h>
|
|
|
|
|
|
namespace DB
|
|
{
|
|
namespace
|
|
{
|
|
template <typename Factory>
|
|
void fillRow(MutableColumns & res_columns, const String & name, UInt64 is_aggregate, const Factory & f)
|
|
{
|
|
res_columns[0]->insert(name);
|
|
res_columns[1]->insert(is_aggregate);
|
|
res_columns[2]->insert(f.isCaseInsensitive(name));
|
|
if (f.isAlias(name))
|
|
res_columns[3]->insert(f.aliasTo(name));
|
|
else
|
|
res_columns[3]->insertDefault();
|
|
}
|
|
}
|
|
|
|
NamesAndTypesList StorageSystemFunctions::getNamesAndTypes()
|
|
{
|
|
return {
|
|
{"name", std::make_shared<DataTypeString>()},
|
|
{"is_aggregate", std::make_shared<DataTypeUInt8>()},
|
|
{"case_insensitive", std::make_shared<DataTypeUInt8>()},
|
|
{"alias_to", std::make_shared<DataTypeString>()},
|
|
};
|
|
}
|
|
|
|
void StorageSystemFunctions::fillData(MutableColumns & res_columns, const Context &, const SelectQueryInfo &) const
|
|
{
|
|
const auto & functions_factory = FunctionFactory::instance();
|
|
const auto & function_names = functions_factory.getAllRegisteredNames();
|
|
for (const auto & function_name : function_names)
|
|
{
|
|
fillRow(res_columns, function_name, UInt64(0), functions_factory);
|
|
}
|
|
|
|
const auto & aggregate_functions_factory = AggregateFunctionFactory::instance();
|
|
const auto & aggregate_function_names = aggregate_functions_factory.getAllRegisteredNames();
|
|
for (const auto & function_name : aggregate_function_names)
|
|
{
|
|
fillRow(res_columns, function_name, UInt64(1), aggregate_functions_factory);
|
|
}
|
|
}
|
|
}
|