原创文章,禁止转载。
更新视图时也会修改对应的基本表,但有时更新视图会产生报错。
不可更新视图的原因
1.视图中包含的字段不是基础表中的直接字段
如果视图 S_G 中的字段 Gavg 是由聚合函数(如 AVG())计算而来,那么它不直接对应于基础表中的某一列。在这种情况下,数据库无法确定如何将对 Gavg 的更新操作传递到基础表。
示例:
CREATE VIEW S_G AS
SELECT Sno, AVG(Grade) AS Gavg
FROM SC
GROUP BY Sno;
- Gavg 是从 SC 表中的 Grade 列计算得出的。
- AVG() 是聚合函数,结果无法对应到基础表 SC 的单个字段。
- 更新 Gavg 无法被转换为对 SC 表的更新操作,因此视图不可更新。
2.视图中包含的字段来自多表
如果视图是基于多表连接创建的,例如:
CREATE VIEW S_G AS
SELECT SC.Sno, SC.Grade, Students.Sname
FROM SC
JOIN Students ON SC.Sno = Students