【MySQL】为什么更新视图时报错?

原创文章,禁止转载。

更新视图时也会修改对应的基本表,但有时更新视图会产生报错。

不可更新视图的原因

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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

秋说

感谢打赏

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值