ClickHouse/dbms/src/Parsers/ParserSelectQuery.cpp

260 lines
7.4 KiB
C++
Raw Normal View History

2016-03-07 01:08:01 +00:00
#include <memory>
2011-08-28 00:31:30 +00:00
#include <DB/Parsers/ASTSelectQuery.h>
2011-08-28 02:22:23 +00:00
#include <DB/Parsers/ASTIdentifier.h>
2011-08-28 00:31:30 +00:00
#include <DB/Parsers/IParserBase.h>
#include <DB/Parsers/CommonParsers.h>
#include <DB/Parsers/ExpressionElementParsers.h>
#include <DB/Parsers/ExpressionListParsers.h>
#include <DB/Parsers/ParserSetQuery.h>
#include <DB/Parsers/ParserSampleRatio.h>
2011-08-28 00:31:30 +00:00
#include <DB/Parsers/ParserSelectQuery.h>
2016-07-18 00:14:24 +00:00
#include <DB/Parsers/ParserTablesInSelectQuery.h>
2011-08-28 00:31:30 +00:00
namespace DB
{
2016-03-07 01:08:01 +00:00
namespace ErrorCodes
{
extern const int SYNTAX_ERROR;
}
2011-08-28 00:31:30 +00:00
bool ParserSelectQuery::parseImpl(Pos & pos, Pos end, ASTPtr & node, Pos & max_parsed_pos, Expected & expected)
2011-08-28 00:31:30 +00:00
{
Pos begin = pos;
auto select_query = std::make_shared<ASTSelectQuery>();
2011-08-28 00:31:30 +00:00
node = select_query;
ParserString s_select("SELECT", true, true);
2013-06-01 07:43:57 +00:00
ParserString s_distinct("DISTINCT", true, true);
2011-08-28 00:31:30 +00:00
ParserString s_from("FROM", true, true);
ParserString s_prewhere("PREWHERE", true, true);
2011-08-28 00:31:30 +00:00
ParserString s_where("WHERE", true, true);
ParserString s_group("GROUP", true, true);
ParserString s_by("BY", true, true);
ParserString s_with("WITH", true, true);
ParserString s_totals("TOTALS", true, true);
2011-08-28 00:31:30 +00:00
ParserString s_having("HAVING", true, true);
ParserString s_order("ORDER", true, true);
ParserString s_limit("LIMIT", true, true);
ParserString s_settings("SETTINGS", true, true);
2014-12-16 10:39:02 +00:00
ParserString s_union("UNION", true, true);
ParserString s_all("ALL", true, true);
ParserNotEmptyExpressionList exp_list(false);
2016-07-18 00:14:24 +00:00
ParserNotEmptyExpressionList exp_list_for_select_clause(true); /// Allows aliases without AS keyword.
ParserExpressionWithOptionalAlias exp_elem(false);
2011-09-04 05:14:52 +00:00
ParserOrderByExpressionList order_list;
2011-08-28 00:31:30 +00:00
ws.ignore(pos, end);
2013-06-01 07:43:57 +00:00
/// SELECT [DISTINCT] expr list
2011-08-28 00:31:30 +00:00
{
if (!s_select.ignore(pos, end, max_parsed_pos, expected))
2011-08-28 00:31:30 +00:00
return false;
ws.ignore(pos, end);
if (s_distinct.ignore(pos, end, max_parsed_pos, expected))
2013-06-01 07:43:57 +00:00
{
select_query->distinct = true;
ws.ignore(pos, end);
}
if (!exp_list_for_select_clause.parse(pos, end, select_query->select_expression_list, max_parsed_pos, expected))
2011-08-28 00:31:30 +00:00
return false;
ws.ignore(pos, end);
}
/// FROM database.table или FROM table или FROM (subquery) или FROM tableFunction
if (s_from.ignore(pos, end, max_parsed_pos, expected))
2011-08-28 00:31:30 +00:00
{
ws.ignore(pos, end);
2016-07-18 00:14:24 +00:00
if (!ParserTablesInSelectQuery().parse(pos, end, select_query->tables, max_parsed_pos, expected))
return false;
ws.ignore(pos, end);
}
/// PREWHERE expr
if (s_prewhere.ignore(pos, end, max_parsed_pos, expected))
{
ws.ignore(pos, end);
if (!exp_elem.parse(pos, end, select_query->prewhere_expression, max_parsed_pos, expected))
return false;
ws.ignore(pos, end);
}
2011-08-28 00:31:30 +00:00
/// WHERE expr
if (s_where.ignore(pos, end, max_parsed_pos, expected))
2011-08-28 00:31:30 +00:00
{
ws.ignore(pos, end);
if (!exp_elem.parse(pos, end, select_query->where_expression, max_parsed_pos, expected))
2011-08-28 00:31:30 +00:00
return false;
ws.ignore(pos, end);
}
/// GROUP BY expr list
if (s_group.ignore(pos, end, max_parsed_pos, expected))
2011-08-28 00:31:30 +00:00
{
ws.ignore(pos, end);
if (!s_by.ignore(pos, end, max_parsed_pos, expected))
2011-08-28 00:31:30 +00:00
return false;
if (!exp_list.parse(pos, end, select_query->group_expression_list, max_parsed_pos, expected))
2011-08-28 00:31:30 +00:00
return false;
ws.ignore(pos, end);
}
/// WITH TOTALS
if (s_with.ignore(pos, end, max_parsed_pos, expected))
{
ws.ignore(pos, end);
if (!s_totals.ignore(pos, end, max_parsed_pos, expected))
return false;
select_query->group_by_with_totals = true;
ws.ignore(pos, end);
2011-08-28 00:31:30 +00:00
}
/// HAVING expr
if (s_having.ignore(pos, end, max_parsed_pos, expected))
2011-08-28 00:31:30 +00:00
{
ws.ignore(pos, end);
if (!exp_elem.parse(pos, end, select_query->having_expression, max_parsed_pos, expected))
2011-08-28 00:31:30 +00:00
return false;
ws.ignore(pos, end);
}
2013-05-29 11:33:55 +00:00
/// ORDER BY expr ASC|DESC COLLATE 'locale' list
if (s_order.ignore(pos, end, max_parsed_pos, expected))
2011-08-28 00:31:30 +00:00
{
ws.ignore(pos, end);
if (!s_by.ignore(pos, end, max_parsed_pos, expected))
2011-08-28 00:31:30 +00:00
return false;
if (!order_list.parse(pos, end, select_query->order_expression_list, max_parsed_pos, expected))
2011-08-28 00:31:30 +00:00
return false;
ws.ignore(pos, end);
}
/// LIMIT length или LIMIT offset, length
if (s_limit.ignore(pos, end, max_parsed_pos, expected))
2011-08-28 00:31:30 +00:00
{
ws.ignore(pos, end);
ParserString s_comma(",");
ParserNumber num;
if (!num.parse(pos, end, select_query->limit_length, max_parsed_pos, expected))
2011-08-28 00:31:30 +00:00
return false;
ws.ignore(pos, end);
if (s_comma.ignore(pos, end, max_parsed_pos, expected))
2011-08-28 00:31:30 +00:00
{
select_query->limit_offset = select_query->limit_length;
if (!num.parse(pos, end, select_query->limit_length, max_parsed_pos, expected))
2011-08-28 00:31:30 +00:00
return false;
ws.ignore(pos, end);
}
}
/// SETTINGS key1 = value1, key2 = value2, ...
if (s_settings.ignore(pos, end, max_parsed_pos, expected))
{
ws.ignore(pos, end);
ParserSetQuery parser_settings(true);
if (!parser_settings.parse(pos, end, select_query->settings, max_parsed_pos, expected))
return false;
ws.ignore(pos, end);
}
2011-10-30 05:19:41 +00:00
/// FORMAT format_name
2015-10-21 14:57:10 +00:00
if (!parseFormat(*select_query, pos, end, node, max_parsed_pos, expected))
return false;
// UNION ALL select query
if (s_union.ignore(pos, end, max_parsed_pos, expected))
{
ws.ignore(pos, end);
if (s_all.ignore(pos, end, max_parsed_pos, expected))
2014-12-16 10:39:02 +00:00
{
if (select_query->format)
2015-06-25 17:38:54 +00:00
{
/// FORMAT может быть задан только в последнем запросе цепочки UNION ALL.
expected = "FORMAT only in the last SELECT of the UNION ALL chain";
return false;
}
2014-12-16 10:39:02 +00:00
ParserSelectQuery select_p;
if (!select_p.parse(pos, end, select_query->next_union_all, max_parsed_pos, expected))
2014-12-16 10:39:02 +00:00
return false;
auto next_select_query = static_cast<ASTSelectQuery *>(&*select_query->next_union_all);
next_select_query->prev_union_all = node.get();
2014-12-16 10:39:02 +00:00
}
else
return false;
ws.ignore(pos, end);
}
select_query->range = StringRange(begin, pos);
2011-08-28 00:31:30 +00:00
select_query->children.push_back(select_query->select_expression_list);
if (select_query->database)
select_query->children.push_back(select_query->database);
if (select_query->table)
select_query->children.push_back(select_query->table);
if (select_query->array_join_expression_list)
select_query->children.push_back(select_query->array_join_expression_list);
if (select_query->join)
select_query->children.push_back(select_query->join);
if (select_query->sample_size)
select_query->children.push_back(select_query->sample_size);
if (select_query->sample_offset)
select_query->children.push_back(select_query->sample_offset);
if (select_query->prewhere_expression)
select_query->children.push_back(select_query->prewhere_expression);
if (select_query->where_expression)
select_query->children.push_back(select_query->where_expression);
2011-08-28 00:31:30 +00:00
if (select_query->group_expression_list)
select_query->children.push_back(select_query->group_expression_list);
if (select_query->having_expression)
select_query->children.push_back(select_query->having_expression);
if (select_query->order_expression_list)
select_query->children.push_back(select_query->order_expression_list);
if (select_query->limit_offset)
select_query->children.push_back(select_query->limit_offset);
if (select_query->limit_length)
select_query->children.push_back(select_query->limit_length);
if (select_query->settings)
select_query->children.push_back(select_query->settings);
2011-10-30 05:19:41 +00:00
if (select_query->format)
select_query->children.push_back(select_query->format);
if (select_query->next_union_all)
select_query->children.push_back(select_query->next_union_all);
2011-08-28 00:31:30 +00:00
return true;
}
}