2022-06-07 05:20:46 +00:00
|
|
|
#include <Parsers/ASTDeleteQuery.h>
|
|
|
|
#include <Common/quoteString.h>
|
|
|
|
|
|
|
|
namespace DB
|
|
|
|
{
|
|
|
|
|
|
|
|
String ASTDeleteQuery::getID(char delim) const
|
|
|
|
{
|
|
|
|
return "DeleteQuery" + (delim + getDatabase()) + delim + getTable();
|
|
|
|
}
|
|
|
|
|
|
|
|
ASTPtr ASTDeleteQuery::clone() const
|
|
|
|
{
|
|
|
|
auto res = std::make_shared<ASTDeleteQuery>(*this);
|
|
|
|
res->children.clear();
|
|
|
|
|
|
|
|
if (predicate)
|
|
|
|
{
|
|
|
|
res->predicate = predicate->clone();
|
|
|
|
res->children.push_back(res->predicate);
|
|
|
|
}
|
|
|
|
|
2022-09-19 18:58:21 +00:00
|
|
|
if (settings_ast)
|
|
|
|
{
|
|
|
|
res->settings_ast = settings_ast->clone();
|
|
|
|
res->children.push_back(res->settings_ast);
|
|
|
|
}
|
|
|
|
|
2022-06-07 05:20:46 +00:00
|
|
|
cloneTableOptions(*res);
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
|
|
|
void ASTDeleteQuery::formatQueryImpl(const FormatSettings & settings, FormatState & state, FormatStateStacked frame) const
|
|
|
|
{
|
|
|
|
settings.ostr << (settings.hilite ? hilite_keyword : "") << "DELETE FROM " << (settings.hilite ? hilite_none : "");
|
|
|
|
|
|
|
|
if (database)
|
|
|
|
{
|
|
|
|
settings.ostr << backQuoteIfNeed(getDatabase());
|
|
|
|
settings.ostr << ".";
|
|
|
|
}
|
|
|
|
settings.ostr << backQuoteIfNeed(getTable());
|
|
|
|
|
2023-01-30 15:42:52 +00:00
|
|
|
formatOnCluster(settings);
|
|
|
|
|
2022-06-07 05:20:46 +00:00
|
|
|
settings.ostr << (settings.hilite ? hilite_keyword : "") << " WHERE " << (settings.hilite ? hilite_none : "");
|
|
|
|
predicate->formatImpl(settings, state, frame);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|