Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
2dot5
ClickHouse
提交
c27cc5a3
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,发现更多精彩内容 >>
提交
c27cc5a3
编写于
4月 29, 2013
作者:
V
Vyacheslav Alipov
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
sign rewrite fixes, count() is working, others do not [#CONV-6778]
上级
55d143e9
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
12 addition
and
7 deletion
+12
-7
dbms/src/Interpreters/Expression.cpp
dbms/src/Interpreters/Expression.cpp
+12
-7
未找到文件。
dbms/src/Interpreters/Expression.cpp
浏览文件 @
c27cc5a3
...
...
@@ -123,7 +123,8 @@ ASTPtr Expression::createSignColumn()
ASTIdentifier
*
p_sign_column
=
new
ASTIdentifier
;
ASTIdentifier
&
sign_column
=
*
p_sign_column
;
ASTPtr
sign_column_node
=
new
ASTIdentifier
(
ast
->
range
,
sign_column_name
);
sign_column
.
type
=
findColumn
(
sign_column_name
)
->
second
;
sign_column
.
name
=
sign_column_name
;
sign_column
.
type
=
storage
->
getDataTypeByName
(
sign_column_name
);
return
sign_column_node
;
}
...
...
@@ -144,9 +145,10 @@ ASTPtr Expression::rewriteCount()
ASTFunction
*
p_sum
=
new
ASTFunction
;
ASTFunction
&
sum
=
*
p_sum
;
ASTPtr
sum_node
=
p_sum
;
sum
.
name
=
"sum"
;
sum
.
arguments
=
exp_list_node
;
sum
.
children
.
push_back
(
exp_list_node
);
sum
.
aggregate_function
=
context
.
getAggregateFunctionFactory
().
get
(
"sum"
,
argument_types
);
sum
.
aggregate_function
=
context
.
getAggregateFunctionFactory
().
get
(
sum
.
name
,
argument_types
);
sum
.
return_type
=
sum
.
aggregate_function
->
getReturnType
();
required_columns
.
insert
(
sign_column_name
);
...
...
@@ -163,13 +165,14 @@ ASTPtr Expression::rewriteSum(const ASTFunction * node)
ASTExpressionList
&
mult_exp_list
=
*
p_mult_exp_list
;
ASTPtr
mult_exp_list_node
=
p_mult_exp_list
;
mult_exp_list
.
children
.
push_back
(
createSignColumn
());
mult_exp_list
.
children
.
push_back
(
node
->
arguments
);
mult_exp_list
.
children
.
push_back
(
node
->
arguments
->
children
[
0
]
);
/// x * Sign
ASTFunction
*
p_mult
=
new
ASTFunction
;
ASTFunction
&
mult
=
*
p_mult
;
ASTPtr
mult_node
=
p_mult
;
mult
.
function
=
context
.
getFunctionFactory
().
get
(
"multiply"
,
context
);
mult
.
name
=
"multiply"
;
mult
.
function
=
context
.
getFunctionFactory
().
get
(
mult
.
name
,
context
);
mult
.
arguments
=
mult_exp_list_node
;
mult
.
children
.
push_back
(
mult_exp_list_node
);
mult
.
return_type
=
mult
.
function
->
getReturnType
(
getArgumentTypes
(
mult_exp_list
));
...
...
@@ -186,9 +189,10 @@ ASTPtr Expression::rewriteSum(const ASTFunction * node)
ASTFunction
*
p_sum
=
new
ASTFunction
;
ASTFunction
&
sum
=
*
p_sum
;
ASTPtr
sum_node
=
p_sum
;
sum
.
name
=
"sum"
;
sum
.
arguments
=
exp_list_node
;
sum
.
children
.
push_back
(
exp_list_node
);
sum
.
aggregate_function
=
context
.
getAggregateFunctionFactory
().
get
(
"sum"
,
argument_types
);
sum
.
aggregate_function
=
context
.
getAggregateFunctionFactory
().
get
(
sum
.
name
,
argument_types
);
sum
.
return_type
=
sum
.
aggregate_function
->
getReturnType
();
required_columns
.
insert
(
sign_column_name
);
...
...
@@ -210,8 +214,9 @@ ASTPtr Expression::rewriteAvg(const ASTFunction * node)
/// sum(Sign * x) / sum(Sign)
ASTFunction
*
p_div
=
new
ASTFunction
;
ASTFunction
&
div
=
*
p_div
;
ASTPtr
div_node
=
p_div
;
div
.
function
=
context
.
getFunctionFactory
().
get
(
"divide"
,
context
);
ASTPtr
div_node
=
p_div
;
div
.
name
=
"divide"
;
div
.
function
=
context
.
getFunctionFactory
().
get
(
div
.
name
,
context
);
div
.
arguments
=
div_exp_list_node
;
div
.
children
.
push_back
(
div_exp_list_node
);
div
.
return_type
=
div
.
function
->
getReturnType
(
getArgumentTypes
(
div_exp_list
));
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录