当此表上存在已定义的物化视图时,似乎无法从表中删除列。例如,假设我们有这个表:
> 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来说有多贵?
答案 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;