Postgresql 中文操作指南

ALTER MATERIALIZED VIEW

ALTER MATERIALIZED VIEW - 更改物化视图的定义

Synopsis

ALTER MATERIALIZED VIEW [ IF EXISTS ] name
    action [, ... ]
ALTER MATERIALIZED VIEW name
    [ NO ] DEPENDS ON EXTENSION extension_name
ALTER MATERIALIZED VIEW [ IF EXISTS ] name
    RENAME [ COLUMN ] column_name TO new_column_name
ALTER MATERIALIZED VIEW [ IF EXISTS ] name
    RENAME TO new_name
ALTER MATERIALIZED VIEW [ IF EXISTS ] name
    SET SCHEMA new_schema
ALTER MATERIALIZED VIEW ALL IN TABLESPACE name [ OWNED BY role_name [, ... ] ]
    SET TABLESPACE new_tablespace [ NOWAIT ]

where action is one of:

    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 | DEFAULT }
    ALTER [ COLUMN ] column_name SET COMPRESSION compression_method
    CLUSTER ON index_name
    SET WITHOUT CLUSTER
    SET ACCESS METHOD new_access_method
    SET TABLESPACE new_tablespace
    SET ( storage_parameter [= value] [, ... ] )
    RESET ( storage_parameter [, ... ] )
    OWNER TO { new_owner | CURRENT_ROLE | CURRENT_USER | SESSION_USER }

Description

ALTER MATERIALIZED VIEW 更改现有物化视图的各种辅助属性。

您必须拥有物化视图才能使用 ALTER MATERIALIZED VIEW 。要更改物化视图的架构,还必须对新架构具有 CREATE 权限。要更改所有者,您必须能够将 SET ROLE 更改为新拥有者角色,该角色必须对物化视图的架构具有 CREATE 权限。(这些限制强制要求更改所有者不会执行您无法通过删除和重新创建物化视图所执行的任何操作。但是,超级用户无论如何都可以更改任何视图的所有权。)

ALTER MATERIALIZED VIEW 可用的语句子形式和动作是 ALTER TABLE 中可用的语句子形式和动作的子集,并且在用于物化视图时具有相同的含义。有关详细信息,请参阅 ALTER TABLE 的说明。

Parameters

  • name

    • 现有物化视图的名称(可选择限定架构)。

  • column_name

    • 新列或现有列的名称。

  • extension_name

    • 物化视图要依赖的扩展的名称(或 NO 已指定,则不再依赖)。标记为依赖于某个扩展的物化视图将自动在该扩展删除时删除。

  • new_column_name

    • 现有列的新名称。

  • new_owner

    • 物化视图的新所有者的用户名。

  • new_name

    • 物化视图的新名称。

  • new_schema

    • 物化视图的新架构。

Examples

要将物化视图 foo 重命名为 bar

ALTER MATERIALIZED VIEW foo RENAME TO bar;

Compatibility

ALTER MATERIALIZED VIEW 是 PostgreSQL 扩展。