受支持版本: 当前版本 (18) / 17 / 16 / 15 / 14
开发版本: devel

CREATE MATERIALIZED VIEW

CREATE MATERIALIZED VIEW — 定义一个新物化视图

Synopsis

CREATE MATERIALIZED VIEW [ IF NOT EXISTS ] table_name
    [ (column_name [, ...] ) ]
    [ USING method ]
    [ WITH ( storage_parameter [= value] [, ... ] ) ]
    [ TABLESPACE tablespace_name ]
    AS query
    [ WITH [ NO ] DATA ]

描述

CREATE MATERIALIZED VIEW定义一个基于查询的物化 视图。在发出该命令时,会执行该查询并用其结果填充该视图(除非使用了 WITH NO DATA),之后可以使用 REFRESH MATERIALIZED VIEW来刷新它。

CREATE MATERIALIZED VIEW类似于 CREATE TABLE AS,不过它还会记住用于初始化该视图的 查询,以便后续按需刷新。物化视图具有很多与表相同的属性,但不支持临 时物化视图。

CREATE MATERIALIZED VIEW要求对该物化视图所用的模 式具有CREATE权限。

参数

IF NOT EXISTS #

如果已存在同名物化视图,则不要抛出错误。在这种情况下会发出一条通 知。请注意,不能保证现有的物化视图与原本会创建出来的那个物化视图 有任何相似之处。

table_name #

要创建的物化视图名称(可以带模式限定)。该名称必须与同一模式中的 任何其他关系(表、序列、索引、视图、物化视图或外部表)的名称不同。

column_name #

新物化视图中的列名。如果没有提供列名,则采用查询输出列的名称。

USING method #

该可选子句指定用于存储新物化视图内容的表访问方法;该方法必须是 TABLE类型的访问方法。详见 Chapter 62。如果未指定此选项,则会为新物化视图选择默 认表访问方法。详见default_table_access_method

WITH ( storage_parameter [= value] [, ... ] ) #

该子句为新物化视图指定可选的存储参数;更多信息见 CREATE TABLE文档中的 Storage Parameters。凡是 CREATE TABLE支持的参数, CREATE MATERIALIZED VIEW也同样支持。另见 CREATE TABLE

TABLESPACE tablespace_name #

tablespace_name是 在其中创建新物化视图的表空间名称。如果没有指定, 将查阅default_tablespace

query #

一个SELECTTABLEVALUES命令。 该查询将在一种安全受限的操作中运行。特别是,调用那些自身会创建临 时表的函数将会失败。另外,在该查询运行期间, search_path会被临时改为 pg_catalog, pg_temp

WITH [ NO ] DATA #

该子句指定是否在创建时填充物化视图。如果不填充,则该物化视图会被 标记为不可扫描,在使用REFRESH MATERIALIZED VIEW 之前不能查询。

兼容性

CREATE MATERIALIZED VIEW是一种 PostgreSQL扩展。

提交更正

如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。