mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-11-26 17:41:59 +00:00
Prevent LOGICAL_ERROR on CREATE TABLE as MaterializedView
This commit is contained in:
parent
6e33443926
commit
84459052b6
@ -977,6 +977,13 @@ void InterpreterCreateQuery::setEngine(ASTCreateQuery & create) const
|
|||||||
if (as_create.is_ordinary_view)
|
if (as_create.is_ordinary_view)
|
||||||
throw Exception(ErrorCodes::INCORRECT_QUERY, "Cannot CREATE a table AS {}, it is a View", qualified_name);
|
throw Exception(ErrorCodes::INCORRECT_QUERY, "Cannot CREATE a table AS {}, it is a View", qualified_name);
|
||||||
|
|
||||||
|
if (as_create.is_materialized_view && as_create.to_table_id)
|
||||||
|
throw Exception(
|
||||||
|
ErrorCodes::INCORRECT_QUERY,
|
||||||
|
"Cannot CREATE a table AS {}, it is a Materialized View without storage. Use \"AS `{}`\" instead",
|
||||||
|
qualified_name,
|
||||||
|
as_create.to_table_id.getQualifiedName());
|
||||||
|
|
||||||
if (as_create.is_live_view)
|
if (as_create.is_live_view)
|
||||||
throw Exception(ErrorCodes::INCORRECT_QUERY, "Cannot CREATE a table AS {}, it is a Live View", qualified_name);
|
throw Exception(ErrorCodes::INCORRECT_QUERY, "Cannot CREATE a table AS {}, it is a Live View", qualified_name);
|
||||||
|
|
||||||
|
14
tests/queries/0_stateless/03161_create_table_as_mv.sql
Normal file
14
tests/queries/0_stateless/03161_create_table_as_mv.sql
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
DROP TABLE IF EXISTS base_table;
|
||||||
|
DROP TABLE IF EXISTS target_table;
|
||||||
|
DROP TABLE IF EXISTS mv_from_base_to_target;
|
||||||
|
DROP TABLE IF EXISTS mv_with_storage;
|
||||||
|
DROP TABLE IF EXISTS other_table_1;
|
||||||
|
DROP TABLE IF EXISTS other_table_2;
|
||||||
|
|
||||||
|
CREATE TABLE base_table (date DateTime, id String, cost Float64) ENGINE = MergeTree() ORDER BY date;
|
||||||
|
CREATE TABLE target_table (id String, total AggregateFunction(sum, Float64)) ENGINE = MergeTree() ORDER BY id;
|
||||||
|
CREATE MATERIALIZED VIEW mv_from_base_to_target TO target_table AS Select id, sumState(cost) FROM base_table GROUP BY id;
|
||||||
|
CREATE MATERIALIZED VIEW mv_with_storage ENGINE=MergeTree() ORDER BY id AS Select id, sumState(cost) FROM base_table GROUP BY id;
|
||||||
|
|
||||||
|
CREATE TABLE other_table_1 AS mv_with_storage;
|
||||||
|
CREATE TABLE other_table_2 AS mv_from_base_to_target; -- { serverError INCORRECT_QUERY }
|
Loading…
Reference in New Issue
Block a user