数据仓库服务 GAUSSDB(DWS)-CREATE VIEW:可更新的视图

时间:2024-01-26 16:15:25

可更新的视图

当开启视图可更新参数(enable_view_update)后,系统允许对简单视图使用INSERT,UPDATE、DELETE和MERGE INTO语句进行更新。(MERGE INTO语句更新仅8.1.2及以上版本支持)

满足以下所有条件的视图可进行更新:

  • 视图定义的FROM语句中只能有一个普通表,不能是系统表、外表、delta表、toast表、错误表。
  • 视图中包含可更新的列,这些列是对基础表可更新列的简单引用。
  • 视图定义不能包含WITH、DISTINCT、GROUP BY、ORDER BY、FOR UPDATE、FOR SHARE、HAVING、TABLESAMPLE、LIMIT、OFFSET子句。
  • 视图定义不能包含UNION、INTERSECT、EXCEPT集合操作。
  • 视图定义的选择列表不能包含聚集函数、窗口函数、返回集合的函数。
  • 对于INSERT、UPDATE和DELETE语句,视图上不能有触发时机为INSTEAD OF的触发器。对于MERGE INTO语句,视图和基础表上都不能有触发器。
  • 视图定义不能包含子链接。
  • 视图定义不能包含属性为VOLATILE的函数(函数值可以在一次表扫描内改变的函数)
  • 视图定义不能对表的分布键所在列起别名,或将普通列起别名为分布键列名。
  • 视图更新操作中包含RETURNING子句时,视图定义中的列只能来自于基础表。

如果可更新的视图定义包含WHERE条件,则该条件将会限制UPDATE和DELETE语句修改基础表上的行。如果UPDATE语句更改行后不再满足WHERE条件,更新后通过视图将无法查询到。类似地如果INSERT命令插入了不满足WHERE条件的数据,插入后通过视图将无法查询到。在视图上执行插入、更新或删除的用户必须在视图和表上具有相应的插入、更新或删除权限。

support.huaweicloud.com/sqlreference-820-dws/dws_06_0187.html