mysql视图

mysql视图

  • 视图是一种虚拟表,本身不具有数据,占用很少的内存空间,它是SQL中的一个重要概念。
  • 视图建立在已有表的基础上,视图赖以建立的这些表称为基表。
    在这里插入图片描述
  • 视图的创建和删除只影响视图本身,不影响对应的基表。但是当对视图中的数据进行增加、删除和修改操作时,数据表中的数据会相应地发生变化,反之亦然。
  • 向视图提供数据内容的语句为SELECT语句,可以将视图理解为存储起来的SELECT语句。(在数据库中视图不会保存数据,数据真正保存在数据表中。当对视图的数据进行增加删除和修改操作时,数据表的数据相应地发生变化,反之亦然)
  • 视图,是向用户提供基表数据的另一种表现形式。通常情况下,小型项目的数据库可以不使用视图,但是在大型项目中,以及数据表比较复杂的情况下,视图的价值就凸显出来了,它可以帮助我们把经常查询的结果集放到虚拟表中,提升使用效率。理解和使用起来都非常方便。

如何创建视图

创建视图前准备

注意:这里只会将数据复制过来,不会讲索引主键等复制过来
在这里插入图片描述

针对于单表创建视图

在这里插入图片描述
查询语句中字段的别名会作为视图中字段
也可以用这种形式取别名
![//img-blog.csdnimg.cn/2443495bbc0740d69d8cb0586af09260.png)]](https://img-blog.csdnimg.cn/2443495bbc0740d69d8cb0586af09260.png)
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

针对于多表的视图

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

基于视图创建视图

在这里插入图片描述
在这里插入图片描述

查看视图

在这里插入图片描述

更改视图中的数据

更新视图中的数据:
在这里插入图片描述
不能更新视图中的数据:
要想让视图可更新,视图中的行和底层基本表中的行之间必须存在一对一关系。
在这里插入图片描述
注意:虽然可以更新视图数据,但总的来说,视图作为虚拟表,主要用于方便查询,不建议更新视图的数据,对视图数据的更改,都是通过对实际数据表里数据的操作来完成的。

修改视图,删除视图

方式一:
在这里插入图片描述
在这里插入图片描述
方式二:
在这里插入图片描述
在这里插入图片描述

删除视图

删除视图只是删除视图的定义,并不会删除基表的数据。
删除视图的语法是:
DROP VIEW IF EXISTS 视图名称;
DROP VIEW empvu80
基于视图a,b创建了新的视图c,如果将视图a或者视图b删除,会导致视图c的查询失败。这样的视图c需要手动删除或修改,否则影响使用。

总结

视图优点:

  • 操作简单:将经常使用的查询操作定义为视图,可以使开发人员不需要关心视图对应的数据表的结构、表与表之间的关联关系,也不需要关心数据表之间的业务逻辑和查询条件,而只需要简单地操作视图即可,极大简化了开发人员对数据库的操作。
  • 减少数据冗余:视图跟实际数据表不一样,它存储的是查询语句。所以在使用的时候,我们要通过定义视图的查询语句来获取结果集。而视图本身不存储数据,不占用数据存储的资源,减少了数据冗余。
  • 数据安全:MySQL将用户对数据的访问限制在某些数据的结果集上,而这些数据的结果集可以使用视图来实现。用户不必直接查询或操作数据表。这也可以理解为视图具有隔离性。视图相当于在用户和实际的数据表之间加了一层虚拟表。
  • 适应灵活多变的需求
  • 能够分解复杂的查询逻辑

视图缺点:

  • 如果我们在实际数据表的基础上创建了视图,那么如果实际数据库表的结构变更了,我们就需要及时对相关的视图进行相应的维护,可读性不好,容易变成系统的潜在隐患,可读性不好。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

龙崎流河

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

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

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

打赏作者

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

抵扣说明:

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

余额充值