Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
2dot5
ClickHouse
提交
b5e4d069
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,发现更多精彩内容 >>
提交
b5e4d069
编写于
3月 16, 2018
作者:
A
Alexey Milovidov
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Disallow PREWHERE, SAMPLE, FINAL in MATERIALIZED VIEWs [#CLICKHOUSE-2].
上级
a16dd1ce
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
30 addition
and
3 deletion
+30
-3
dbms/src/Common/ErrorCodes.cpp
dbms/src/Common/ErrorCodes.cpp
+1
-0
dbms/src/Storages/StorageMaterializedView.cpp
dbms/src/Storages/StorageMaterializedView.cpp
+29
-3
未找到文件。
dbms/src/Common/ErrorCodes.cpp
浏览文件 @
b5e4d069
...
...
@@ -372,6 +372,7 @@ namespace ErrorCodes
extern
const
int
QUERY_WAS_CANCELLED
=
394
;
extern
const
int
FUNCTION_THROW_IF_VALUE_IS_NON_ZERO
=
395
;
extern
const
int
TOO_MANY_ROWS_OR_BYTES
=
396
;
extern
const
int
QUERY_IS_NOT_SUPPORTED_IN_MATERIALIZED_VIEW
=
397
;
extern
const
int
KEEPER_EXCEPTION
=
999
;
...
...
dbms/src/Storages/StorageMaterializedView.cpp
浏览文件 @
b5e4d069
#include <Parsers/ASTSelectQuery.h>
#include <Parsers/ASTSelectWithUnionQuery.h>
#include <Parsers/ASTCreateQuery.h>
#include <Parsers/ASTDropQuery.h>
#include <Parsers/ASTIdentifier.h>
...
...
@@ -22,6 +23,7 @@ namespace ErrorCodes
{
extern
const
int
LOGICAL_ERROR
;
extern
const
int
INCORRECT_QUERY
;
extern
const
int
QUERY_IS_NOT_SUPPORTED_IN_MATERIALIZED_VIEW
;
}
...
...
@@ -46,7 +48,7 @@ static void extractDependentTable(ASTSelectQuery & query, String & select_databa
else
if
(
auto
ast_select
=
typeid_cast
<
ASTSelectWithUnionQuery
*>
(
query_table
.
get
()))
{
if
(
ast_select
->
list_of_selects
->
children
.
size
()
!=
1
)
throw
Exception
(
"UNION is not supported for MATERIALIZED VIEW"
,
ErrorCodes
::
INCORRECT_QUERY
);
throw
Exception
(
"UNION is not supported for MATERIALIZED VIEW"
,
ErrorCodes
::
QUERY_IS_NOT_SUPPORTED_IN_MATERIALIZED_VIEW
);
auto
&
inner_query
=
ast_select
->
list_of_selects
->
children
.
at
(
0
);
...
...
@@ -59,6 +61,28 @@ static void extractDependentTable(ASTSelectQuery & query, String & select_databa
}
static
void
checkAllowedQueries
(
const
ASTSelectQuery
&
query
)
{
if
(
query
.
prewhere_expression
||
query
.
final
()
||
query
.
sample_size
())
throw
Exception
(
"MATERIALIZED VIEW cannot have PREWHERE, SAMPLE or FINAL."
,
DB
::
ErrorCodes
::
QUERY_IS_NOT_SUPPORTED_IN_MATERIALIZED_VIEW
);
auto
query_table
=
query
.
table
();
if
(
!
query_table
)
return
;
if
(
auto
ast_select
=
typeid_cast
<
const
ASTSelectWithUnionQuery
*>
(
query_table
.
get
()))
{
if
(
ast_select
->
list_of_selects
->
children
.
size
()
!=
1
)
throw
Exception
(
"UNION is not supported for MATERIALIZED VIEW"
,
ErrorCodes
::
QUERY_IS_NOT_SUPPORTED_IN_MATERIALIZED_VIEW
);
const
auto
&
inner_query
=
ast_select
->
list_of_selects
->
children
.
at
(
0
);
checkAllowedQueries
(
typeid_cast
<
const
ASTSelectQuery
&>
(
*
inner_query
));
}
}
StorageMaterializedView
::
StorageMaterializedView
(
const
String
&
table_name_
,
const
String
&
database_name_
,
...
...
@@ -80,11 +104,13 @@ StorageMaterializedView::StorageMaterializedView(
/// Default value, if only table name exist in the query
select_database_name
=
local_context
.
getCurrentDatabase
();
if
(
query
.
select
->
list_of_selects
->
children
.
size
()
!=
1
)
throw
Exception
(
"UNION is not supported for MATERIALIZED VIEW"
,
ErrorCodes
::
INCORRECT_QUERY
);
throw
Exception
(
"UNION is not supported for MATERIALIZED VIEW"
,
ErrorCodes
::
QUERY_IS_NOT_SUPPORTED_IN_MATERIALIZED_VIEW
);
inner_query
=
query
.
select
->
list_of_selects
->
children
.
at
(
0
);
extractDependentTable
(
typeid_cast
<
ASTSelectQuery
&>
(
*
inner_query
),
select_database_name
,
select_table_name
);
ASTSelectQuery
&
select_query
=
typeid_cast
<
ASTSelectQuery
&>
(
*
inner_query
);
extractDependentTable
(
select_query
,
select_database_name
,
select_table_name
);
checkAllowedQueries
(
select_query
);
if
(
!
select_table_name
.
empty
())
global_context
.
addDependency
(
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录