视图的可更新性与视图中查询的定义是有关的
一、mysql中那些试图使不可更新的?以下类型的视图是不可更新的
1.包含以下关键字的sql语句:聚合函数(sum、min、max、count)、distinct、group by 、having、union或者uinon all
2.常量视图
3.select 中包含子查询
4.join
5.from一个不可更新的试图
6.where字句的子查询引用了from字句中的表
二、更新视图条件限制
WITH[CASCADED | LOCAL] CHECK OPTION确定了更新视图的条件。
LOCAL代表只要满足本视图的条件就可以更新
CASCADED 则必须满足所有针对该视图的所有视图条件才可以更新
如果没有明确是local还是cascade,默认是cascade
为了便于理解还是通过实例来说明
已知t3表的数据结构如下:
-- 创建视图 ldq_t1 CREATE VIEW ldq_t1 AS SELECT * FROM t3 WHERE id1 > 10 WITH CHECK OPTION ; -- 查询ldq_t1中的所有结果 SELECT * FROM ldq_t1; -- 创建视图 ldq_t2 CREATE VIEW ldq_t2 AS SELECT * FROM ldq_t1 WHERE id1 <p>总结:<span style="color:rgb(90,90,90); font-family:'microsoft yahei'; font-size:18px; line-height:27px; white-space:pre-wrap">WITH LOCAL CHECK OPTION 修饰的视图,在更新的时候,只需要保证更新后的记录仍然存在该视图中就可以了,否认报错。而<span style="color:rgb(90,90,90); font-family:'microsoft yahei'; font-size:18px; line-height:27px; white-space:pre-wrap">WITH CASCADED CHECK OPTION修饰视图,必须保证更新后的记录仍然存在该视图以及跟该视图有关系的试图中就可以了。</span></span><br></p><p> 以上就是mysql中视图更新详解的内容,更多相关内容请关注PHP中文网(www.php.cn)!<br></p><p></p>
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END