mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-11-17 21:24:28 +00:00
55 lines
1.1 KiB
C++
55 lines
1.1 KiB
C++
#pragma once
|
|
|
|
#include <DB/Parsers/IAST.h>
|
|
#include <unordered_map>
|
|
|
|
|
|
namespace DB
|
|
{
|
|
|
|
class WriteBuffer;
|
|
|
|
|
|
/** Build a map: alias -> AST node.
|
|
*
|
|
* Also fill information about what kind each alias has:
|
|
* - expression alias;
|
|
* - table alias;
|
|
* - ARRAY JOIN alias.
|
|
*
|
|
* As extension to standard SQL, aliases could be specified and used in any part of query.
|
|
* Example: SELECT a, (1 AS a) + 1 AS b FROM t GROUP BY a, b
|
|
* Alias could be used in query before it is defined.
|
|
*
|
|
* Aliases could not be redefined. Example: 1 AS a, a + 1 AS a - is prohibited.
|
|
*
|
|
* Don't descend into subqueries (as aliases are local inside them).
|
|
*/
|
|
struct CollectAliases
|
|
{
|
|
void process(const ASTPtr & ast);
|
|
|
|
enum class Kind
|
|
{
|
|
Expression, /// Example: SELECT a AS b, f(x) AS y
|
|
Table, /// Example: SELECT t.* FROM (SELECT 1) AS t
|
|
ArrayJoin /// Example: SELECT t.x.a FROM t ARRAY JOIN arr AS x
|
|
};
|
|
|
|
struct AliasInfo
|
|
{
|
|
ASTPtr node;
|
|
Kind kind;
|
|
|
|
AliasInfo(ASTPtr node, Kind kind) : node(node), kind(kind) {}
|
|
};
|
|
|
|
using Aliases = std::unordered_map<String, AliasInfo>;
|
|
Aliases aliases;
|
|
|
|
/// Debug output
|
|
void dump(WriteBuffer & out) const;
|
|
};
|
|
|
|
}
|