mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-04 21:42:39 +00:00
47 lines
1.2 KiB
C++
47 lines
1.2 KiB
C++
#include <Interpreters/InterpreterShowFunctionsQuery.h>
|
|
|
|
#include <Interpreters/Context.h>
|
|
#include <Interpreters/DatabaseCatalog.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 systemDb = DatabaseCatalog::instance().getSystemDatabase();
|
|
|
|
String rewritten_query = fmt::format(
|
|
R"(
|
|
SELECT *
|
|
FROM {}.{})",
|
|
systemDb->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;
|
|
}
|
|
|
|
}
|