Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
2dot5
ClickHouse
提交
3fbb61cb
C
ClickHouse
项目概览
2dot5
/
ClickHouse
通知
3
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
C
ClickHouse
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
3fbb61cb
编写于
8月 15, 2015
作者:
A
Alexey Milovidov
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
dbms: fixed error with multiple GLOBAL subqueries [#METR-17622].
上级
4724de39
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
13 addition
and
7 deletion
+13
-7
dbms/src/Interpreters/ExpressionAnalyzer.cpp
dbms/src/Interpreters/ExpressionAnalyzer.cpp
+11
-7
dbms/tests/queries/0_stateless/00213_multiple_global_in.reference
...ts/queries/0_stateless/00213_multiple_global_in.reference
+1
-0
dbms/tests/queries/0_stateless/00213_multiple_global_in.sql
dbms/tests/queries/0_stateless/00213_multiple_global_in.sql
+1
-0
未找到文件。
dbms/src/Interpreters/ExpressionAnalyzer.cpp
浏览文件 @
3fbb61cb
...
...
@@ -239,9 +239,10 @@ void ExpressionAnalyzer::analyzeAggregation()
void
ExpressionAnalyzer
::
initGlobalSubqueriesAndExternalTables
()
{
/// Преобразует GLOBAL-подзапросы во внешние таблицы; кладёт их в словарь external_tables: name -> StoragePtr.
initGlobalSubqueries
(
ast
);
///
Создаёт словарь external_tables: name -> StoragePtr
.
///
Добавляет уже существующие внешние таблицы (не подзапросы) в словарь external_tables
.
findExternalTables
(
ast
);
}
...
...
@@ -896,10 +897,6 @@ static SharedPtr<InterpreterSelectQuery> interpretSubquery(
void
ExpressionAnalyzer
::
addExternalStorage
(
ASTPtr
&
subquery_or_table_name
)
{
/// Сгенерируем имя для внешней таблицы.
while
(
context
.
tryGetExternalTable
(
"_data"
+
toString
(
external_table_id
)))
++
external_table_id
;
if
(
const
ASTIdentifier
*
table
=
typeid_cast
<
const
ASTIdentifier
*>
(
&*
subquery_or_table_name
))
{
/// Если это уже внешняя таблица, ничего заполять не нужно. Просто запоминаем ее наличие.
...
...
@@ -910,13 +907,20 @@ void ExpressionAnalyzer::addExternalStorage(ASTPtr & subquery_or_table_name)
}
}
/// Сгенерируем имя для внешней таблицы.
String
external_table_name
=
"_data"
+
toString
(
external_table_id
);
while
(
context
.
tryGetExternalTable
(
external_table_name
)
||
external_tables
.
count
(
external_table_name
))
{
++
external_table_id
;
external_table_name
=
"_data"
+
toString
(
external_table_id
);
}
SharedPtr
<
InterpreterSelectQuery
>
interpreter
=
interpretSubquery
(
subquery_or_table_name
,
context
,
subquery_depth
+
1
);
Block
sample
=
interpreter
->
getSampleBlock
();
NamesAndTypesListPtr
columns
=
new
NamesAndTypesList
(
sample
.
getColumnsList
());
String
external_table_name
=
"_data"
+
toString
(
external_table_id
);
/** Заменяем подзапрос на имя временной таблицы.
* Именно в таком виде, запрос отправится на удалённый сервер.
* На удалённый сервер отправится эта временная таблица, и на его стороне,
...
...
dbms/tests/queries/0_stateless/00213_multiple_global_in.reference
0 → 100644
浏览文件 @
3fbb61cb
1 1
dbms/tests/queries/0_stateless/00213_multiple_global_in.sql
0 → 100644
浏览文件 @
3fbb61cb
SELECT
1
GLOBAL
IN
(
SELECT
1
),
2
GLOBAL
IN
(
SELECT
2
)
FROM
remote
(
'127.0.0.2'
,
system
.
one
);
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录