2019-01-30 12:01:00 +00:00
|
|
|
#pragma once
|
|
|
|
|
2020-02-10 15:50:12 +00:00
|
|
|
#include <Core/Block.h>
|
|
|
|
#include <Storages/IStorage_fwd.h>
|
2019-01-30 12:01:00 +00:00
|
|
|
#include <Parsers/IAST.h>
|
2019-09-09 19:43:37 +00:00
|
|
|
#include <Interpreters/IJoin.h>
|
2019-01-30 12:01:00 +00:00
|
|
|
#include <Interpreters/PreparedSets.h>
|
|
|
|
|
|
|
|
|
|
|
|
namespace DB
|
|
|
|
{
|
|
|
|
|
|
|
|
class InterpreterSelectWithUnionQuery;
|
2020-02-10 15:50:12 +00:00
|
|
|
class ExpressionActions;
|
|
|
|
using ExpressionActionsPtr = std::shared_ptr<ExpressionActions>;
|
2020-09-15 13:25:14 +00:00
|
|
|
class QueryPlan;
|
2019-01-30 12:01:00 +00:00
|
|
|
|
|
|
|
/// Information on what to do when executing a subquery in the [GLOBAL] IN/JOIN section.
|
|
|
|
struct SubqueryForSet
|
|
|
|
{
|
|
|
|
/// The source is obtained using the InterpreterSelectQuery subquery.
|
2020-09-15 13:25:14 +00:00
|
|
|
std::unique_ptr<QueryPlan> source;
|
2019-01-30 12:01:00 +00:00
|
|
|
|
|
|
|
/// If set, build it from result.
|
|
|
|
SetPtr set;
|
|
|
|
JoinPtr join;
|
|
|
|
/// Apply this actions to joined block.
|
|
|
|
ExpressionActionsPtr joined_block_actions;
|
2019-09-09 19:43:37 +00:00
|
|
|
Block sample_block; /// source->getHeader() + column renames
|
2019-01-30 12:01:00 +00:00
|
|
|
|
|
|
|
/// If set, put the result into the table.
|
|
|
|
/// This is a temporary table for transferring to remote servers for distributed query processing.
|
|
|
|
StoragePtr table;
|
|
|
|
|
|
|
|
void makeSource(std::shared_ptr<InterpreterSelectWithUnionQuery> & interpreter,
|
2019-09-04 16:20:02 +00:00
|
|
|
NamesWithAliases && joined_block_aliases_);
|
2019-01-30 12:01:00 +00:00
|
|
|
|
2019-09-09 19:43:37 +00:00
|
|
|
void setJoinActions(ExpressionActionsPtr actions);
|
|
|
|
|
|
|
|
bool insertJoinedBlock(Block & block);
|
2020-09-01 13:53:11 +00:00
|
|
|
void setTotals(Block totals);
|
2019-01-30 12:01:00 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
NamesWithAliases joined_block_aliases; /// Rename column from joined block from this list.
|
2019-09-09 19:43:37 +00:00
|
|
|
|
2020-03-31 10:38:24 +00:00
|
|
|
/// Rename source right table column names into qualified column names if they conflicts with left table ones.
|
2019-09-09 19:43:37 +00:00
|
|
|
void renameColumns(Block & block);
|
2019-01-30 12:01:00 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/// ID of subquery -> what to do with it.
|
|
|
|
using SubqueriesForSets = std::unordered_map<String, SubqueryForSet>;
|
|
|
|
|
|
|
|
}
|