ALTER VIEW

Name

ALTER VIEW -- 更改视图定义

Synopsis

ALTER VIEW [ IF EXISTS ] _name_ ALTER [ COLUMN ] _column_name_ SET DEFAULT _expression_
ALTER VIEW [ IF EXISTS ] _name_ ALTER [ COLUMN ] _column_name_ DROP DEFAULT
ALTER VIEW [ IF EXISTS ] _name_ OWNER TO _new_owner_
ALTER VIEW [ IF EXISTS ] _name_ RENAME TO _new_name_
ALTER VIEW [ IF EXISTS ] _name_ SET SCHEMA _new_schema_
ALTER VIEW [ IF EXISTS ] _name_ SET ( _view_option_name_ [= _view_option_value_] [, ... ] )
ALTER VIEW [ IF EXISTS ] _name_ RESET ( _view_option_name_ [, ... ] )

描述

ALTER VIEW更改视图的各种辅助属性。 (如果你是更改视图的查询定义,要使用CREATE OR REPLACE VIEW。)

你必须是视图的所有者才可以使用ALTER VIEW。 要改变视图的模式,您必须要有新模式的CREATE权限。 要改变视图的所有者,您必须是新所属角色的直接或者 间接的成员,并且此角色必须有视图模式的CREATE权限。 (这些限制强制 更改所有者不会做任何您通过删除或者重建视图时不能做的操作。但是,一个超级用户不管怎样都可以更改任何视图的所属关系。)

参数

_name_

一个已有视图的名称(可以有模式修饰) 。

IF EXISTS

使用这个选项,如果视图不存在时不会产生错误,仅有会有一个提示信息。

SET/DROP DEFAULT

这种形式设置或删除一个列的缺省值。 当INSERTUPDATE命令的对象是视图时,使用这个选项时可以在视图相关的规则和触发器启动前,设置视图列的缺省值。 视图列的缺省值也会优先于视图相关联表的列缺省值生效。

_new_owner_

视图新所有者的用户名称。

_new_name_

视图的新名称。

_new_schema_

视图的新模式。

_view_option_name_

将要设置或复位的选项名称。

_view_option_value_

视图选项的新值。

注意

由于历史原因,ALTER TABLE也可用于视图; 但是ALTER TABLE命令中允许与视图相关的选项与上面所列选项相同。

例子

重命名视图foobar:

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 现在是空值
INSERT INTO a_view(id) VALUES(2);  -- ts 现在是当前时间

兼容性

ALTER VIEW是PostgreSQL对SQL标准的扩展。

参见

CREATE VIEW, DROP VIEW