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

REFRESH MATERIALIZED VIEW

REFRESH MATERIALIZED VIEW — 替换物化视图的内容

Synopsis

REFRESH MATERIALIZED VIEW [ CONCURRENTLY ] name
    [ WITH [ NO ] DATA ]

描述

REFRESH MATERIALIZED VIEW会完全替换物化视图的内容。 要执行此命令,必须拥有该物化视图的MAINTAIN权限。旧 内容会被丢弃。如果指定了WITH DATA(或者默认如 此),则会执行其底层查询以生成新数据,并使物化视图处于可扫描状态。如 果指定了WITH NO DATA,则不会生成新数据,并使物化视 图处于不可扫描状态。

不得同时指定CONCURRENTLYWITH NO DATA

参数

CONCURRENTLY #

刷新物化视图时,不会阻塞针对该物化视图的并发查询。如果不使用此选 项,一次影响很多行的刷新通常会占用更少的资源并且更快完成,但可能会 阻塞其他试图从该物化视图读取的连接。在只影响少量行的情况下,此选项 可能更快。

只有当该物化视图上至少有一个仅使用列名且涵盖所有行的 UNIQUE索引时,才允许使用此选项;也就是说,它不 能是表达式索引,也不能带有WHERE子句。

只有在该物化视图已经填充数据时,才能使用此选项。

即使使用了此选项,对于任意一个物化视图,一次也只能运行一个 REFRESH

name #

要刷新的物化视图名称(可以带模式限定)。

注解

如果物化视图的定义查询中带有ORDER BY子句,则该物 化视图的原始内容会按该顺序排列;但REFRESH MATERIALIZED VIEW并不保证保留这种顺序。

REFRESH MATERIALIZED VIEW运行期间,search_path会被临时改为pg_catalog, pg_temp

示例

这个命令会使用物化视图order_summary定义中的查询来 替换其内容,并使其处于可扫描状态:

REFRESH MATERIALIZED VIEW order_summary;

这个命令会释放与物化视图annual_statistics_basis相关 的存储,并使其处于不可扫描状态:

REFRESH MATERIALIZED VIEW annual_statistics_basis WITH NO DATA;

兼容性

REFRESH MATERIALIZED VIEWPostgreSQL的扩展。

提交更正

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