ALTER MATERIALIZED VIEW — 更改物化视图的定义
ALTER MATERIALIZED VIEW [ IF EXISTS ]name
action
[, ... ] ALTER MATERIALIZED VIEWname
[ NO ] DEPENDS ON EXTENSIONextension_name
ALTER MATERIALIZED VIEW [ IF EXISTS ]name
RENAME [ COLUMN ]column_name
TOnew_column_name
ALTER MATERIALIZED VIEW [ IF EXISTS ]name
RENAME TOnew_name
ALTER MATERIALIZED VIEW [ IF EXISTS ]name
SET SCHEMAnew_schema
ALTER MATERIALIZED VIEW ALL IN TABLESPACEname
[ OWNED BYrole_name
[, ... ] ] SET TABLESPACEnew_tablespace
[ NOWAIT ] whereaction
is one of: ALTER [ COLUMN ]column_name
SET STATISTICSinteger
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 | DEFAULT } ALTER [ COLUMN ]column_name
SET COMPRESSIONcompression_method
CLUSTER ONindex_name
SET WITHOUT CLUSTER SET ACCESS METHODnew_access_method
SET TABLESPACEnew_tablespace
SET (storage_parameter
[=value
] [, ... ] ) RESET (storage_parameter
[, ... ] ) OWNER TO {new_owner
| CURRENT_ROLE | CURRENT_USER | SESSION_USER }
ALTER MATERIALIZED VIEW
更改现有物化视图的各种辅助属性。
要使用 ALTER MATERIALIZED VIEW
,您必须拥有该物化视图。要更改物化视图的模式,您还必须对新模式拥有 CREATE
权限。要更改所有者,您必须能够将 SET ROLE
设置为新的拥有者角色,并且该角色必须对物化视图的模式具有 CREATE
权限。(这些限制强制要求更改所有者不能执行通过删除和重新创建物化视图无法执行的操作。但是,超级用户无论如何都可以更改任何视图的所有权。)
适用于 ALTER MATERIALIZED VIEW
的子语句形式和操作是 ALTER TABLE
适用的操作子集,并且在用于物化视图时含义相同。有关详细信息,请参阅 ALTER TABLE
的说明。
name
现有物化视图的名称(包含可选项模式限定)。
column_name
现有列的名称。
extension_name
物化视图要依赖的扩展名称(或如果指定了 NO
,则不再依赖)。标记为对扩展有依赖的物化视图会在扩展被删除时自动删除。
new_column_name
现有列的新名称。
new_owner
物化视图的新所有者的用户名。
new_name
物化视图的新名称。
new_schema
物化视图的新模式。
将物化视图 foo
重命名为 bar
ALTER MATERIALIZED VIEW foo RENAME TO bar;
ALTER MATERIALIZED VIEW
是一个 PostgreSQL 扩展。