CREATE MATERIALIZED VIEW — 定义一个新物化视图
CREATE MATERIALIZED VIEW [ IF NOT EXISTS ]table_name[ (column_name[, ...] ) ] [ USINGmethod] [ WITH (storage_parameter[=value] [, ... ] ) ] [ TABLESPACEtablespace_name] ASquery[ 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 #一个SELECT、 TABLE或 VALUES命令。 该查询将在一种安全受限的操作中运行。特别是,调用那些自身会创建临 时表的函数将会失败。另外,在该查询运行期间, search_path会被临时改为 pg_catalog, pg_temp。
WITH [ NO ] DATA #该子句指定是否在创建时填充物化视图。如果不填充,则该物化视图会被 标记为不可扫描,在使用REFRESH MATERIALIZED VIEW 之前不能查询。
CREATE MATERIALIZED VIEW是一种 PostgreSQL扩展。
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。