我需要在Postgres中现有的实例化视图中添加一个新列。
根据此文档: https://www.postgresql.org/docs/9.3/sql-altermaterializedview.html
它说这些是列的选项:
ALTER [ COLUMN ] column_name SET STATISTICS integer ALTER [ COLUMN ] column_name SET ( attribute_option = value [, ... ] ) ALTER [ COLUMN ] column_name RESET ( attribute_option [, ... ] ) ALTER [ COLUMN ] column_name SET STORAGE { PLAIN | EXTERNAL | EXTENDED | MAIN }
但是没有添加新列的语法示例,即使它说 column_name 是“新列或现有列的名称”
...还是应该使用SET SCHEMA new_schema?
答案 0 :(得分:1)
设置架构仅用于将视图移动到其他架构,在这种情况下无济于事。
不幸的是,您唯一的选择是拖放并重新创建实例化视图。
答案 1 :(得分:1)
由于我遇到了同样的问题,我想我会分享一种方法,如果您像我们一样在生产环境中使用物化视图并且长时间不可用是不切实际的。
>正如 Jeremy 提到的,除了删除现有视图并重新创建它之外,别无他法。但是,根据底层查询的复杂性,创建物化视图可能需要大量时间。改进这一点的一种方法是使用不同的临时名称创建物化视图,删除旧名称并将临时名称重命名为最终名称。
使用:
CREATE MATERIALIZED VIEW myViewTmp AS (SELECT ...);
DROP MATERIALIZED VIEW myView;
ALTER MATERIALIZED VIEW myViewTmp RENAME TO myView;
DROP & ALTER 应该只需要 100 毫秒,这是可以接受的。如果没有,您将不得不在代码中更加聪明,让它在部署时查询新版本的物化视图或类似的东西。