首页 > 数据库 >mysql视图

mysql视图

时间:2022-12-13 11:36:25浏览次数:64  
标签:语句 删除 视图 查询 数据表 mysql 数据


mysql视图

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

如何创建视图

创建视图前准备

注意:这里只会将数据复制过来,不会讲索引主键等复制过来

mysql视图_数据库

针对于单表创建视图

mysql视图_mysql_02


查询语句中字段的别名会作为视图中字段

也可以用这种形式取别名

![//img-blog.csdnimg.cn/2443495bbc0740d69d8cb0586af09260.png)]](/i/ll/?i=2443495bbc0740d69d8cb0586af09260.png)

mysql视图_sql_03


mysql视图_新视图_04


mysql视图_新视图_05

针对于多表的视图

mysql视图_mysql_06


mysql视图_sql_07


mysql视图_数据库_08


mysql视图_新视图_09

基于视图创建视图

mysql视图_数据库_10


mysql视图_mysql_11

查看视图

mysql视图_新视图_12

更改视图中的数据

更新视图中的数据:

mysql视图_数据_13


不能更新视图中的数据:

要想让视图可更新,视图中的行和底层基本表中的行之间必须存在一对一关系。

mysql视图_新视图_14


注意:虽然可以更新视图数据,但总的来说,视图作为虚拟表,主要用于方便查询,不建议更新视图的数据,对视图数据的更改,都是通过对实际数据表里数据的操作来完成的。

修改视图,删除视图

方式一:

mysql视图_mysql_15


mysql视图_sql_16


方式二:

mysql视图_sql_17


mysql视图_sql_18

删除视图

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

总结

视图优点:

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

视图缺点:

  • 如果我们在实际数据表的基础上创建了视图,那么如果实际数据库表的结构变更了,我们就需要及时对相关的视图进行相应的维护,可读性不好,容易变成系统的潜在隐患,可读性不好。


标签:语句,删除,视图,查询,数据表,mysql,数据
From: https://blog.51cto.com/u_15911055/5933480

相关文章

  • mysql约束
    文章目录​​mysql约束​​​​非空约束​​​​唯一性约束​​​​主键约束使用​​​​自增列:AUTO_INCREMENT​​​​FOREIGNKEY约束​​​​CHECK约束​​mysql约束为什......
  • mysql安装配置启动
    1.安装&配置&启动MySQL现在的版本主要分为:5.x版本,现在互联网企业中的主流版本,包括:头条、美图、百度、腾讯等互联网公司主流的版本。8.x版本,新增了一些了窗口函......
  • MySQL 不同隔离级别,都使用了什么锁?
    大家好,我是树哥。在上篇文章,我们聊了「MySQL啥时候会用表锁,啥时候用行锁」这个问题。在文章中,我们还留了一个问题,即:如果查询或更新时的数据特别多,是否从行锁会升级为表锁?此......
  • MySql的常用函数2
    2.分组函数功能:做统计使用(统计函数、聚合函数、组函数)分类:sum求和、avg平均值、max最大值、min最小值、count计算个数#1.简单的使用selectsum(salary)fromemploye......
  • 关于MySQL性能优化方式,这一篇就够!
    小鱼已经很长时间没有更新博,主要是去年十月份转战到某上市大厂,由于在工业领域专业知识太薄弱,所以这段时间一直在嗷嗷补工业领域的专业知识,最近在进入review开发代码时,发现一......
  • Centos 7配置使用nginx反向代理mysql
    背景:由于WEB服务和MySQL数据库服务分开部署的,由于网络问题限制,有时需要通过中间代理服务器跳转连接MySQL,所以需要在中间服务器上配置代理。1、添加stearm模块#nginx通常......
  • MySQL-表不能自动生成的解决方式-flowable
    场景同一台服务器中有两个作用相同的数据库,flowable项目启动会自动检测有无创建基础的表,无则创建,第一个数据库无表也可自动启动,但是将数据库切换至第二台数据库无表,则无......
  • 初始Mysql
    为什么学习数据库1.岗位需求2.现在的世界,大数据时代,得数据库者得天下3.被迫需求,存数据4.数据库是所有软件体系中最核心的存在DBA 什么是数据库数据库(DB,DataBase)......
  • Oracle使用dblink连接MySQL以及遇到的一些问题
     Oracle使用dblink连接MySQL以及遇到的一些问题 主要参考了mos文档:DetailedOverviewofConnectingOracletoMySQLUsingDG4ODBCDatabaseLink(文档ID1320645......
  • springboot 简单设置mysql用户名密码加密
     如何将yml文件中暴露的数据库用户名和密码由明文改为密文,提高安全性。个人觉得是最简单的方式实现yml代码,用户名密码使用文章后面提供的加密算法或者自行寻找方法spr......