Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
2dot5
ClickHouse
提交
4bd32c8c
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,发现更多精彩内容 >>
提交
4bd32c8c
编写于
1月 16, 2014
作者:
S
Sergey Fedorov
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
common: utils for virtual columns [METR-9172]
上级
da115c14
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
106 addition
and
0 deletion
+106
-0
dbms/include/DB/Common/VirtualColumnUnitls.h
dbms/include/DB/Common/VirtualColumnUnitls.h
+106
-0
未找到文件。
dbms/include/DB/Common/VirtualColumnUnitls.h
0 → 100644
浏览文件 @
4bd32c8c
#pragma once
#include <DB/Interpreters/Context.h>
#include <DB/DataStreams/AddingConstColumnBlockInputStream.h>
#include <DB/DataTypes/DataTypeString.h>
#include <DB/DataTypes/DataTypesNumberFixed.h>
#include <DB/Parsers/ASTIdentifier.h>
#include <DB/Parsers/ASTExpressionList.h>
#include <DB/Parsers/ASTLiteral.h>
#include <DB/Parsers/ASTSelectQuery.h>
#include <DB/Storages/StoragePtr.h>
namespace
DB
{
static
String
chooseSuffix
(
const
NamesAndTypesList
&
columns
,
const
String
&
name
)
{
int
id
=
0
;
String
current_suffix
;
while
(
true
)
{
bool
done
=
true
;
for
(
auto
&
it
:
columns
)
if
(
it
.
first
==
name
+
current_suffix
)
{
done
=
false
;
break
;
}
if
(
done
)
break
;
id
++
;
current_suffix
=
toString
<
Int32
>
(
id
);
}
return
current_suffix
;
}
static
String
chooseSuffix
(
const
NamesAndTypesList
&
columns
,
const
std
::
vector
<
String
>
&
names
)
{
int
id
=
0
;
String
current_suffix
;
while
(
true
)
{
bool
done
=
true
;
for
(
auto
&
it
:
columns
)
{
for
(
size_t
i
=
0
;
i
<
names
.
size
();
++
i
)
{
if
(
it
.
first
==
names
[
i
]
+
current_suffix
)
{
done
=
false
;
break
;
}
}
if
(
!
done
)
break
;
}
if
(
done
)
break
;
id
++
;
current_suffix
=
toString
<
Int32
>
(
id
);
}
return
current_suffix
;
}
static
void
rewriteEntityInAst
(
ASTPtr
ast
,
const
String
&
column_name
,
const
Field
&
value
)
{
{
ASTSelectQuery
&
select
=
dynamic_cast
<
ASTSelectQuery
&>
(
*
ast
);
ASTExpressionList
&
node
=
dynamic_cast
<
ASTExpressionList
&>
(
*
select
.
select_expression_list
);
ASTs
&
asts
=
node
.
children
;
ASTLiteral
*
cur
=
new
ASTLiteral
(
StringRange
(
NULL
,
NULL
),
value
);
cur
->
alias
=
column_name
;
ASTPtr
column_value
=
cur
;
asts
.
insert
(
asts
.
begin
(),
column_value
);
return
;
}
if
(
ASTExpressionList
*
node
=
dynamic_cast
<
ASTExpressionList
*>
(
&*
ast
))
{
ASTs
&
asts
=
node
->
children
;
for
(
int
i
=
static_cast
<
int
>
(
asts
.
size
())
-
1
;
i
>=
0
;
--
i
)
{
if
(
ASTIdentifier
*
child
=
dynamic_cast
<
ASTIdentifier
*>
(
&*
asts
[
i
]))
{
if
(
child
->
kind
==
ASTIdentifier
::
Column
&&
child
->
getColumnName
()
==
column_name
)
{
ASTLiteral
*
cur
=
new
ASTLiteral
(
StringRange
(
NULL
,
NULL
),
value
);
cur
->
alias
=
column_name
;
ASTPtr
column_value
=
cur
;
asts
.
erase
(
asts
.
begin
()
+
i
);
asts
.
insert
(
asts
.
begin
()
+
i
,
column_value
);
}
}
}
}
for
(
auto
it
:
ast
->
children
)
rewriteEntityInAst
(
it
,
column_name
,
value
);
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录