Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
2dot5
ClickHouse
提交
13fee197
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,发现更多精彩内容 >>
未验证
提交
13fee197
编写于
11月 02, 2020
作者:
A
Amos Bird
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Allow parameterized functions in APPLY
上级
30325689
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
37 addition
and
6 deletion
+37
-6
src/Parsers/ASTColumnsTransformers.cpp
src/Parsers/ASTColumnsTransformers.cpp
+8
-3
src/Parsers/ASTColumnsTransformers.h
src/Parsers/ASTColumnsTransformers.h
+3
-0
src/Parsers/ExpressionElementParsers.cpp
src/Parsers/ExpressionElementParsers.cpp
+16
-3
tests/queries/0_stateless/01470_columns_transformers.reference
.../queries/0_stateless/01470_columns_transformers.reference
+6
-0
tests/queries/0_stateless/01470_columns_transformers.sql
tests/queries/0_stateless/01470_columns_transformers.sql
+4
-0
未找到文件。
src/Parsers/ASTColumnsTransformers.cpp
浏览文件 @
13fee197
...
...
@@ -30,16 +30,21 @@ void IASTColumnsTransformer::transform(const ASTPtr & transformer, ASTs & nodes)
}
}
void
ASTColumnsApplyTransformer
::
formatImpl
(
const
FormatSettings
&
settings
,
FormatState
&
,
FormatStateStacked
)
const
void
ASTColumnsApplyTransformer
::
formatImpl
(
const
FormatSettings
&
settings
,
FormatState
&
state
,
FormatStateStacked
frame
)
const
{
settings
.
ostr
<<
(
settings
.
hilite
?
hilite_keyword
:
""
)
<<
"APPLY"
<<
(
settings
.
hilite
?
hilite_none
:
""
)
<<
"("
<<
func_name
<<
")"
;
settings
.
ostr
<<
(
settings
.
hilite
?
hilite_keyword
:
""
)
<<
"APPLY"
<<
(
settings
.
hilite
?
hilite_none
:
""
)
<<
"("
<<
func_name
;
if
(
parameters
)
parameters
->
formatImpl
(
settings
,
state
,
frame
);
settings
.
ostr
<<
")"
;
}
void
ASTColumnsApplyTransformer
::
transform
(
ASTs
&
nodes
)
const
{
for
(
auto
&
column
:
nodes
)
{
column
=
makeASTFunction
(
func_name
,
column
);
auto
function
=
makeASTFunction
(
func_name
,
column
);
function
->
parameters
=
parameters
;
column
=
function
;
}
}
...
...
src/Parsers/ASTColumnsTransformers.h
浏览文件 @
13fee197
...
...
@@ -18,10 +18,13 @@ public:
ASTPtr
clone
()
const
override
{
auto
res
=
std
::
make_shared
<
ASTColumnsApplyTransformer
>
(
*
this
);
if
(
parameters
)
res
->
parameters
=
parameters
->
clone
();
return
res
;
}
void
transform
(
ASTs
&
nodes
)
const
override
;
String
func_name
;
ASTPtr
parameters
;
protected:
void
formatImpl
(
const
FormatSettings
&
settings
,
FormatState
&
,
FormatStateStacked
)
const
override
;
...
...
src/Parsers/ExpressionElementParsers.cpp
浏览文件 @
13fee197
...
...
@@ -1229,16 +1229,29 @@ bool ParserColumnsTransformers::parseImpl(Pos & pos, ASTPtr & node, Expected & e
return
false
;
++
pos
;
String
func_name
;
if
(
!
parseIdentifierOrStringLiteral
(
pos
,
expected
,
func_name
))
ASTPtr
func_name
;
if
(
!
ParserIdentifier
().
parse
(
pos
,
func_name
,
expected
))
return
false
;
ASTPtr
expr_list_args
;
if
(
pos
->
type
==
TokenType
::
OpeningRoundBracket
)
{
++
pos
;
if
(
!
ParserExpressionList
(
false
).
parse
(
pos
,
expr_list_args
,
expected
))
return
false
;
if
(
pos
->
type
!=
TokenType
::
ClosingRoundBracket
)
return
false
;
++
pos
;
}
if
(
pos
->
type
!=
TokenType
::
ClosingRoundBracket
)
return
false
;
++
pos
;
auto
res
=
std
::
make_shared
<
ASTColumnsApplyTransformer
>
();
res
->
func_name
=
func_name
;
res
->
func_name
=
getIdentifierName
(
func_name
);
res
->
parameters
=
expr_list_args
;
node
=
std
::
move
(
res
);
return
true
;
}
...
...
tests/queries/0_stateless/01470_columns_transformers.reference
浏览文件 @
13fee197
...
...
@@ -77,3 +77,9 @@ SELECT
toFloat64(k),
j
FROM columns_transformers
[110] [9] [173.5]
SELECT
quantiles(0.5)(i),
quantiles(0.5)(j),
quantiles(0.5)(k)
FROM columns_transformers
tests/queries/0_stateless/01470_columns_transformers.sql
浏览文件 @
13fee197
...
...
@@ -41,4 +41,8 @@ EXPLAIN SYNTAX SELECT COLUMNS(i, j, k) APPLY(sum) from columns_transformers;
SELECT
i
,
j
,
COLUMNS
(
i
,
j
,
k
)
APPLY
(
toFloat64
),
COLUMNS
(
i
,
j
)
EXCEPT
(
i
)
from
columns_transformers
;
EXPLAIN
SYNTAX
SELECT
i
,
j
,
COLUMNS
(
i
,
j
,
k
)
APPLY
(
toFloat64
),
COLUMNS
(
i
,
j
)
EXCEPT
(
i
)
from
columns_transformers
;
-- APPLY with parameterized function
SELECT
COLUMNS
(
i
,
j
,
k
)
APPLY
(
quantiles
(
0
.
5
))
from
columns_transformers
;
EXPLAIN
SYNTAX
SELECT
COLUMNS
(
i
,
j
,
k
)
APPLY
(
quantiles
(
0
.
5
))
from
columns_transformers
;
DROP
TABLE
columns_transformers
;
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录