删除具有物化视图的表上的列

时间:2017-11-13 12:38:16

标签: cassandra datastax-enterprise datastax-startup

当此表上存在已定义的物化视图时,似乎无法从表中删除列。例如,假设我们有这个表:

> CREATE TABLE healthera.users (
>   user_id timeuuid PRIMARY KEY,
>   address text,
>   birthday int,
>   forename text,
>   user_password text,
>   username text
> );

我们定义下面的物化视图:

> CREATE MATERIALIZED VIEW users_by_username AS
>   SELECT * FROM users
>   WHERE user_id IS NOT NULL AND username IS NOT NULL
>   PRIMARY KEY (username, user_id);

然后我们改变users表并添加一列:

> ALTER TABLE users ADD last_name text;

当我们尝试从users表中删除此列或任何其他列时,我们会收到此错误:

> ALTER TABLE users DROP last_name ;
> InvalidRequest: Error from server: code=2200 [Invalid query] message="Cannot drop column last_name, depended on by materialized views (healthera.{users_by_username})"

> ALTER TABLE users DROP forename ;
> InvalidRequest: Error from server: code=2200 [Invalid query] message="Cannot drop column forename, depended on by materialized views (healthera.{users_by_username})"

这是预期的吗?我们该如何处理?我们是否需要删除物化视图,删除列,然后再次重新创建物化视图?如果是的话,这对cassandra来说有多贵?

1 个答案:

答案 0 :(得分:3)

您可以向MV的基表添加一列,但即使它不是PK的一部分,也不能删除列。

http://www.doanduyhai.com/blog/?p=1930

在为数据创建现有表格的MV时,它将启动构建过程以在后台填充MV。

您可以查看状态 -

SELECT * FROM system.views_builds_in_progress;
SELECT * FROM system.built_views;