乐趣区

关于mysql:mysql更新视图的限制

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

2、一般来说,能够更新行列子集视图。除列子集视图外,实践上还能够更新一些视图。

实例

-- 创立视图 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;  -- 执行胜利 

以上就是 mysql 更新视图的限度,心愿对大家有所帮忙。更多 mysql 学习指路:Mysql

退出移动版