ALTER VIEW — 更改视图的定义
ALTER VIEW [ IF EXISTS ]nameALTER [ COLUMN ]column_nameSET DEFAULTexpressionALTER VIEW [ IF EXISTS ]nameALTER [ COLUMN ]column_nameDROP DEFAULT ALTER VIEW [ IF EXISTS ]nameOWNER TO {new_owner| CURRENT_ROLE | CURRENT_USER | SESSION_USER } ALTER VIEW [ IF EXISTS ]nameRENAME [ COLUMN ]column_nameTOnew_column_nameALTER VIEW [ IF EXISTS ]nameRENAME TOnew_nameALTER VIEW [ IF EXISTS ]nameSET SCHEMAnew_schemaALTER VIEW [ IF EXISTS ]nameSET (view_option_name[=view_option_value] [, ... ] ) ALTER VIEW [ IF EXISTS ]nameRESET (view_option_name[, ... ] )
ALTER VIEW更改视图的各种辅助属性。 (如果要修改视图的定义查询,请使用 CREATE OR REPLACE VIEW。)
要使用 ALTER VIEW,你必须是该视图的拥有者。 要更改视图的模式,你还必须拥有新模式上的 CREATE 权限。要更改拥有者,你必须能够对新的拥有角色执行 SET ROLE,并且该角色必须拥有该视图所在模式上的 CREATE 权限。(这些限制确保,更改拥有者不会做出任何 你不能通过删除并重新创建该视图来完成的事情。不过,超级用户无论如何都可以 更改任何视图的所有权。)
name #现有视图的名称(可以带模式限定)。
column_name #现有列的名称。
new_column_name #现有列的新名称。
IF EXISTS #如果视图不存在,则不抛出错误,而是发出一条提示。
SET/DROP DEFAULT #这些形式用于设置或移除列的默认值。对于任何以该视图为目标的 INSERT 或 UPDATE 命令, 视图列的默认值都会在应用该视图上的任何规则或触发器之前被代入。 因此,视图的默认值将优先于底层关系中的任何默认值。
new_owner #视图新拥有者的用户名。
new_name #该视图的新名称。
new_schema #该视图的新模式。
SET ( view_option_name [= view_option_value] [, ... ] )RESET ( view_option_name [, ... ] ) #设置或重置视图选项。目前支持的选项有:
出于历史原因,视图也可以使用 ALTER TABLE; 但允许用于视图的 ALTER TABLE 变体,仅限于与上面所示 形式等价的那些。
将视图 foo 重命名为 bar:
ALTER VIEW foo RENAME TO bar;
要为一个可更新视图附加默认列值:
CREATE TABLE base_table (id int, ts timestamptz); CREATE VIEW a_view AS SELECT * FROM base_table; ALTER VIEW a_view ALTER COLUMN ts SET DEFAULT now(); INSERT INTO base_table(id) VALUES(1); -- ts will receive a NULL INSERT INTO a_view(id) VALUES(2); -- ts will receive the current time
ALTER VIEW 是 PostgreSQL 对 SQL 标准的扩展。
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。