mysql视图
- 视图是一种虚拟表,本身不具有数据,占用很少的内存空间,它是SQL中的一个重要概念。
- 视图建立在已有表的基础上,视图赖以建立的这些表称为基表。
- 视图的创建和删除只影响视图本身,不影响对应的基表。但是当对视图中的数据进行增加、删除和修改操作时,数据表中的数据会相应地发生变化,反之亦然。
- 向视图提供数据内容的语句为SELECT语句,可以将视图理解为存储起来的SELECT语句。(在数据库中视图不会保存数据,数据真正保存在数据表中。当对视图的数据进行增加删除和修改操作时,数据表的数据相应地发生变化,反之亦然)
- 视图,是向用户提供基表数据的另一种表现形式。通常情况下,小型项目的数据库可以不使用视图,但是在大型项目中,以及数据表比较复杂的情况下,视图的价值就凸显出来了,它可以帮助我们把经常查询的结果集放到虚拟表中,提升使用效率。理解和使用起来都非常方便。
如何创建视图
创建视图前准备
注意:这里只会将数据复制过来,不会讲索引主键等复制过来
针对于单表创建视图
查询语句中字段的别名会作为视图中字段
也可以用这种形式取别名
![//img-blog.csdnimg.cn/2443495bbc0740d69d8cb0586af09260.png)]](/i/ll/?i=2443495bbc0740d69d8cb0586af09260.png)
针对于多表的视图
基于视图创建视图
查看视图
更改视图中的数据
更新视图中的数据:
不能更新视图中的数据:
要想让视图可更新,视图中的行和底层基本表中的行之间必须存在一对一关系。
注意:虽然可以更新视图数据,但总的来说,视图作为虚拟表,主要用于方便查询,不建议更新视图的数据,对视图数据的更改,都是通过对实际数据表里数据的操作来完成的。
修改视图,删除视图
方式一:
方式二:
删除视图
删除视图只是删除视图的定义,并不会删除基表的数据。
删除视图的语法是:
DROP VIEW IF EXISTS 视图名称;
DROP VIEW empvu80
基于视图a,b创建了新的视图c,如果将视图a或者视图b删除,会导致视图c的查询失败。这样的视图c需要手动删除或修改,否则影响使用。
总结
视图优点:
- 操作简单:将经常使用的查询操作定义为视图,可以使开发人员不需要关心视图对应的数据表的结构、表与表之间的关联关系,也不需要关心数据表之间的业务逻辑和查询条件,而只需要简单地操作视图即可,极大简化了开发人员对数据库的操作。
- 减少数据冗余:视图跟实际数据表不一样,它存储的是查询语句。所以在使用的时候,我们要通过定义视图的查询语句来获取结果集。而视图本身不存储数据,不占用数据存储的资源,减少了数据冗余。
- 数据安全:MySQL将用户对数据的访问限制在某些数据的结果集上,而这些数据的结果集可以使用视图来实现。用户不必直接查询或操作数据表。这也可以理解为视图具有隔离性。视图相当于在用户和实际的数据表之间加了一层虚拟表。
- 适应灵活多变的需求
- 能够分解复杂的查询逻辑
视图缺点:
- 如果我们在实际数据表的基础上创建了视图,那么如果实际数据库表的结构变更了,我们就需要及时对相关的视图进行相应的维护,可读性不好,容易变成系统的潜在隐患,可读性不好。