MySQL 视图更新

视图更新

829618ebdb7a4564a3bc1c3547320007.jpg

1.视图简介

1.视图不是表,不能直接存储数据,是一张虚拟的表,视图和数据库的表存在着对应的关系,我们在某些情况下是可以通过视图来操作数据库的表,这样可以简化查询操作(一般情况下视图是用来查询用的),在某种条件下是可以利用视图来更新数据库表中的数据的

 

2.一般情况下,在创建有条件限制的视图时,加上 with check option命令

 

2.视图的更新问题

某些视图是可更新的。也就是说,可以在UPDATE、DELETE或INSERT等语句中使用它们,以更新基表的内容。对于可更新的视图,在视图中的行和基表中的行之间必须具有一对一的关系。如果视图包含下述结构中的任何一种,那么它就是不可更新的:

  1. 聚合函数(SUM(), MIN(), MAX(), COUNT()等)。
  2. DISTINCT
  3. GROUP BY
  4. HAVING
  5. UNION或UNION ALL
  6. 位于选择列表中的子查询
  7. Join
  8. FROM子句中的不可更新视图
  9. WHERE子句中的子查询,引用FROM子句中的表
  10. 仅引用文字值(在该情况下,没有要更新的基本表)
  11. ALGORITHM = TEMPTABLE(使用临时表总会使视图成为不可更新的)                             

3. 使用视图的好处:

  1. 简化用户操作

  2. 使用户能以多种态度看待同一数据

  3. 视图对重构数据库提供了一定程度的逻辑独立性

  4. 视图能对机密数据提供安全保护

 

4.WITH  [CASCADED|LOCAL]  CHECK  OPTION 能不能决定视图是否能更新?

  1. 这两个参数的基本定义如下:
    LOCAL参数表示更新视图时只要满足该视图本身定义的条件即可。
    CASCADED参数表示更新视图时需要满足所有相关视图和表的条件。没有指明时,该参数为默认值。

  2. 对于with check option用法,总结如下:

    1. 视图只操作它可以查询出来的数据,对于它查询不出的数据,即使基表有,也不可以通过视图来操作。
    2. 对于update,有with check option,要保证update后,数据要被视图查询出来
    3. 对于delete,有无with check option都一样
    4. 对于insert,有with check option,要保证insert后,数据要被视图查询出来
    5. 对于没有where 子句的视图,使用with check option是多余的

 

注意:
1.视图中虽然可以更新数据,但是有很多的限制。一般情况下,最好将视图作为查询数据的虚拟表,而不要通过视图更新数据。因为,使用视图更新数据时,如果没有全面考虑在视图中更新数据的限制,就可能会造成数据更新失败。

2.视图与表是一对一关系情况:如果没有其它约束(如视图中没有的字段,在基本表中是必填字段情况),是可以进行增删改数据操作;

3.视图与表是一对多关系情况:如果只修改一张表的数据,且没有其它约束(如视图中没有的字段,在基本表中是必填字段情况),是可以进行改数据操作,如以下语句,操作成功;

 

文章参考了MySQL视图

 

 

 

 

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

噗-噗

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值