Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
2dot5
ClickHouse
提交
0e26b649
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,发现更多精彩内容 >>
提交
0e26b649
编写于
9月 02, 2015
作者:
A
Alexey Milovidov
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
dbms: allowed columns with duplicate names in GLOBAL subqueries [#METR-17552].
上级
57c03c0d
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
41 addition
and
0 deletion
+41
-0
dbms/src/Interpreters/ExpressionAnalyzer.cpp
dbms/src/Interpreters/ExpressionAnalyzer.cpp
+37
-0
dbms/tests/queries/0_stateless/00217_global_subquery_columns_with_same_name.reference
...ss/00217_global_subquery_columns_with_same_name.reference
+2
-0
dbms/tests/queries/0_stateless/00217_global_subquery_columns_with_same_name.sql
...tateless/00217_global_subquery_columns_with_same_name.sql
+2
-0
未找到文件。
dbms/src/Interpreters/ExpressionAnalyzer.cpp
浏览文件 @
0e26b649
...
...
@@ -886,8 +886,45 @@ static SharedPtr<InterpreterSelectQuery> interpretSubquery(
select_query
->
children
.
emplace_back
(
select_query
->
table
);
}
else
{
query
=
subquery
->
children
.
at
(
0
);
/** В подзапросе могут быть указаны столбцы с одинаковыми именами. Например, SELECT x, x FROM t
* Это плохо, потому что результат такого запроса нельзя сохранить в таблицу, потому что в таблице не может быть одноимённых столбцов.
* Сохранение в таблицу требуется для GLOBAL-подзапросов.
*
* Чтобы избежать такой ситуации, будем переименовывать одинаковые столбцы.
*/
std
::
set
<
std
::
string
>
all_column_names
;
std
::
set
<
std
::
string
>
assigned_column_names
;
if
(
ASTSelectQuery
*
select
=
typeid_cast
<
ASTSelectQuery
*>
(
query
.
get
()))
{
for
(
auto
&
expr
:
select
->
select_expression_list
->
children
)
all_column_names
.
insert
(
expr
->
getAliasOrColumnName
());
for
(
auto
&
expr
:
select
->
select_expression_list
->
children
)
{
auto
name
=
expr
->
getAliasOrColumnName
();
if
(
!
assigned_column_names
.
insert
(
name
).
second
)
{
size_t
i
=
1
;
while
(
all_column_names
.
end
()
!=
all_column_names
.
find
(
name
+
"_"
+
toString
(
i
)))
++
i
;
name
=
name
+
"_"
+
toString
(
i
);
expr
=
expr
->
clone
();
/// Отменяет склейку одинаковых выражений в дереве.
expr
->
setAlias
(
name
);
all_column_names
.
insert
(
name
);
assigned_column_names
.
insert
(
name
);
}
}
}
}
if
(
required_columns
.
empty
())
return
new
InterpreterSelectQuery
(
query
,
subquery_context
,
QueryProcessingStage
::
Complete
,
subquery_depth
+
1
);
else
...
...
dbms/tests/queries/0_stateless/00217_global_subquery_columns_with_same_name.reference
0 → 100644
浏览文件 @
0e26b649
42 1
1
dbms/tests/queries/0_stateless/00217_global_subquery_columns_with_same_name.sql
0 → 100644
浏览文件 @
0e26b649
SELECT
k
,
a
FROM
(
SELECT
42
AS
k
FROM
remote
(
'127.0.0.1'
,
system
.
one
))
GLOBAL
ALL
FULL
OUTER
JOIN
(
SELECT
42
AS
k
,
1
AS
a
,
a
)
USING
k
;
SELECT
1
FROM
remote
(
'127.0.0.1'
,
system
.
one
)
WHERE
(
1
,
1
)
GLOBAL
IN
(
SELECT
1
AS
a
,
a
);
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录