mysql怎么更新视图

网友投稿 841 2023-07-08

mysql怎么更新视图

mysql怎么更新视图

1、有些视图是不可更新的,因为这些视图的更新不能唯一有意义地转换为相应的基本表。

2、一般来说,可以更新行列子集视图。除列子集视图外,理论上还可以更新一些视图。

实例

-- 创建视图 ldq_t1CREATE VIEW ldq_t1 ASSELECT *FROM t3WHERE id1 > 10 WITH CHECK OPTION ;-- 查询ldq_t1中的所有结果SELECT * FROM ldq_t1; -- 创建视图 ldq_t2CREATE VIEW ldq_t2 ASSELECT *FROM ldq_t1WHERE id1 < 30 WITH LOCAL CHECK OPTION ; -- 创建视图 ldq_t3CREATE VIEW ldq_t3 ASSELECT *FROM ldq_t1WHERE id1 < 30 WITH CHECK OPTION ; -- 更新视图ldq_t2(只有ldq_t2中存在的数据都可以更新)SELECT * FROM ldq_t2; -- 查看ldq_t2当前记录UPDATE ldq_t2 SET id1=5 WHERE id2=22; -- 可以执行成功UPDATE ldq_t2 SET id1=35 WHERE id2=22; -- 将会报错CHECK OPTION failed(因为执行该语句之后,id2=22记录将从ldq_t2消失)UPDATE ldq_t2 SET id1=28 WHERE id2=22; -- 可以执行成功 -- 更新ldq_t3SELECT * FROM ldq_t3;UPDATE ldq_t3 SET id1=5 WHERE id2=22; -- 将会报错CHECK OPTION failed(因为数据更新之后,必须还要保证其仍然在ldq_t3和ldq_t1之中,该语句执行后id2=22记录将从ldq_t1消失)UPDATE ldq_t3 SET id1=15 WHERE id2=22; -- 能够执行成功UPDATE ldq_t3 SET id1=35 WHERE id2=22; -- 将会报错CHECK OPTION failed(因为执行该语句之后,id2=22记录将从ldq_t3消失)DELETE FROM ldq_t3 WHERE id2=22; -- 执行成功登录后复制

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:MySQL数据库如何安装与配置
下一篇:MySql查询方式有哪些
相关文章