mysql中视图更新详解
2016-04-09 12:04
471 查看
视图的可更新性与视图中查询的定义是有关的
by 、having、union或者uinon all
2.常量视图
3.select
中包含子查询
4.join
5.from一个不可更新的试图
6.where字句的子查询引用了from字句中的表
LOCAL代表只要满足本视图的条件就可以更新
CASCADED
则必须满足所有针对该视图的所有视图条件才可以更新
如果没有明确是local还是cascade,默认是cascade
为了便于理解还是通过实例来说明
已知t3表的数据结构如下:
LOCAL CHECK OPTION 修饰的视图,在更新的时候,只需要保证更新后的记录仍然存在该视图中就可以了,否认报错。而WITH CASCADED CHECK OPTION修饰视图,必须保证更新后的记录仍然存在该视图以及跟该视图有关系的试图中就可以了。
一、mysql中那些试图使不可更新的?以下类型的视图是不可更新的
1.包含以下关键字的sql语句:聚合函数(sum、min、max、count)、distinct、groupby 、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 < 30 WITH LOCAL CHECK OPTION ; -- 创建视图 ldq_t3 CREATE VIEW ldq_t3 AS SELECT * FROM ldq_t1 WHERE 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_t3 SELECT * 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; -- 执行成功总结:WITH
LOCAL CHECK OPTION 修饰的视图,在更新的时候,只需要保证更新后的记录仍然存在该视图中就可以了,否认报错。而WITH CASCADED CHECK OPTION修饰视图,必须保证更新后的记录仍然存在该视图以及跟该视图有关系的试图中就可以了。
相关文章推荐
- MySQL之DDL,DQL,DML,DCL
- MySQL--基本内容
- MySQL常见配置参数调优
- user表中存在多条相同user不同host用户信息时MySQL该匹配哪条记录登录?
- SQL Server移植到MySQL(利用工具Sqlyog)
- windows x64 安装 MYSQL教程
- SQL脚本用Navicat导入MySQL数据库出现编码问题
- C#使用MySQLConnectorNet和MySQLDriverCS操作MySQL的方法
- 8.DBCP连接池技术操作MySQL
- mysql 初始化报错 /usr/local/mysql/bin/mysqld:error while loading shared libraries :libaio.so.1
- MySQL 基础(DDL)
- MySQL 基础(DDL)
- mysql sql_mode
- mysql无法启动mysql innob引擎解决
- mysql
- MySQL 启动原理剖析
- Mysql从入门到精通视频课程【典藏版】
- 跟我一起学习MySQL技术内幕(第五版):(第二章学习日记2)
- 在Lamp平台上基于postfix+mysql+dovecot+sasl+courier-authlib+extmail+extman搭建企业级邮件系统
- mysql基本操作