• 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将用户对数据的访问限制在某些数据的结果集上,而这些数据的结果集可以使用视图来实现。用户不必直接查询或操作数据表。这也可以理解为视图具有隔离性。视图相当于在用户和实际的数据表之间加了一层虚拟表。
    • 适应灵活多变的需求
    • 能够分解复杂的查询逻辑

    视图缺点:

    • 如果我们在实际数据表的基础上创建了视图,那么如果实际数据库表的结构变更了,我们就需要及时对相关的视图进行相应的维护,可读性不好,容易变成系统的潜在隐患,可读性不好。
  • 相关阅读:
    【Java 面试题】MySQL与Redis 如何保证双写一致性
    UE4蓝图节点不同颜色代表
    百日筑基第二十天-一头扎进消息队列3-RabbitMQ
    自学网络安全———(黑客技术)
    Instagram Shop如何开通?如何销售?最全面攻略
    vue实现CBC加密/解密
    【Web前端】CSS-盒子模型
    数组的存储和压缩
    [ICS] Inferno(地狱) ETH/IP未授权访问,远程控制工控设备利用工具
    C++ "链链"不忘@必有回响之单链表
  • 原文地址:https://blog.csdn.net/Jiaodaqiaobiluo/article/details/127694610