CREATE [ OR REPLACE ] VIEW name [ ( column_name [, ...] ) ] AS query
CREATE VIEW 定义一个查询的视图。 这个视图不是物理上实际存在(于磁盘)的。具体的说,自动生成一个改写索引规则(一个 ON SELECT 规则)的查询用以支持在视图上的检索。
CREATE OR REPLACE VIEW 类似,不过是如果一个同名的视图已经存在,那么就替换它。 你只能用一个生成相同字段的新查询替换一个视图(也就是说,同样字段名和数据类型)。
如果给出了一个模式名(比如,CREATE VIEW myschema.myview ...),那么该视图是在指定的模式中创建的。 否则它是在当前模式中创建的。 该视图名字必需和同一模式中任何其它视图,表,序列或者索引的名字不同。
请参阅 SELECT [select(7)] 获取有效查询的更多信息。
目前,视图是只读的:系统将不允许在视图上插入,更新,或者删除数据。 你可以通过在视图上创建把插入等动作重写为向其它表做合适操作的规则来实现可更新视图的效果。 更多信息详见
CREATE RULE [create_rule(7)].
使用 DROP VIEW 语句删除视图
请注意视图字段的名字和类型不一定是你们期望的那样。比如,
CREATE VIEW vista AS SELECT 'Hello World';
CREATE VIEW vista AS SELECT text 'Hello World' AS hello;
对视图引用的表的访问的权限由视图的所有者决定。 不过,在视图里调用的函数当作他们直接从使用视图的查询里调用看待。 因此,视图的用户必须有使用视图调用的所有函数的权限。
创建一个由所有喜剧电影组成的视图:
CREATE VIEW comedies AS SELECT * FROM films WHERE kind = 'Comedy';
SQL 标准为 CREATE VIEW 声明了一些附加的功能:
CREATE VIEW name [ ( column [, ...] ) ] AS query [ WITH [ CASCADE | LOCAL ] CHECK OPTION ]
完整的SQL命令可选的子句是:
CREATE OR REPLACE VIEW 是 PostgreSQL 的扩展。