mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-12 17:32:32 +00:00
57 lines
1.6 KiB
C++
57 lines
1.6 KiB
C++
#include <Databases/IDatabase.h>
|
|
#include <Interpreters/Context.h>
|
|
#include <Interpreters/DatabaseCatalog.h>
|
|
#include <Interpreters/InterpreterFactory.h>
|
|
#include <Interpreters/InterpreterShowFunctionsQuery.h>
|
|
#include <Interpreters/executeQuery.h>
|
|
#include <Parsers/ASTShowFunctionsQuery.h>
|
|
|
|
namespace DB
|
|
{
|
|
|
|
InterpreterShowFunctionsQuery::InterpreterShowFunctionsQuery(const ASTPtr & query_ptr_, ContextMutablePtr context_)
|
|
: WithMutableContext(context_), query_ptr(query_ptr_)
|
|
{
|
|
}
|
|
|
|
BlockIO InterpreterShowFunctionsQuery::execute()
|
|
{
|
|
return executeQuery(getRewrittenQuery(), getContext(), QueryFlags{ .internal = true }).second;
|
|
}
|
|
|
|
String InterpreterShowFunctionsQuery::getRewrittenQuery()
|
|
{
|
|
constexpr const char * functions_table = "functions";
|
|
|
|
const auto & query = query_ptr->as<ASTShowFunctionsQuery &>();
|
|
|
|
DatabasePtr system_db = DatabaseCatalog::instance().getSystemDatabase();
|
|
|
|
String rewritten_query = fmt::format(
|
|
R"(
|
|
SELECT *
|
|
FROM {}.{})",
|
|
system_db->getDatabaseName(),
|
|
functions_table);
|
|
|
|
if (!query.like.empty())
|
|
{
|
|
rewritten_query += " WHERE name ";
|
|
rewritten_query += query.case_insensitive_like ? "ILIKE " : "LIKE ";
|
|
rewritten_query += fmt::format("'{}'", query.like);
|
|
}
|
|
|
|
return rewritten_query;
|
|
}
|
|
|
|
void registerInterpreterShowFunctionsQuery(InterpreterFactory & factory)
|
|
{
|
|
auto create_fn = [] (const InterpreterFactory::Arguments & args)
|
|
{
|
|
return std::make_unique<InterpreterShowFunctionsQuery>(args.query, args.context);
|
|
};
|
|
factory.registerInterpreter("InterpreterShowFunctionsQuery", create_fn);
|
|
}
|
|
|
|
}
|