我在Postgres 9.3中有一个物化视图,我想用新列进行更新。但是,其他物化视图也依赖于此视图,错误消息指出,当其他对象依赖视图时,不可能删除视图。
错误:不能删除物化视图latest_charges,因为其他对象依赖它
从文档中还可以看出,替换关键字对于物化视图无效。除了删除所有依赖对象和重建每个对象之外,还有其他捷径吗?
发布于 2017-12-15 10:35:29
对于我的情况,我更喜欢使用视图层来限制下降:
例如:
create table test (myfield int);
insert into test values (1);
create materialized view mv_test as select myfield from test;
create view v_test as select myfield from mv_test;
select * from v_test;
create materialized view mv_test_new as select myfield, myfield+1 as myfield2 from test;
alter view v_test rename to v_test_old;
alter materialized view mv_test rename to mv_test_old;
create view v_test as select myfield,myfield2 from mv_test_new;
select * from v_test;
alter materialized view mv_test_new rename to mv_test;
drop view v_test_old; -- when ready
drop materialized view mv_test_old; -- when ready发布于 2019-07-25 10:19:01
在PgAdmin (Version4.x)中,我可以轻松地修改属性框中的定义(我添加了where子句)。你的问题可以这样解决。
https://dba.stackexchange.com/questions/56304
复制相似问题