MySQL---- 视图(view)


MySQL视图是一个虚拟表,其内容由查询定义。同真实的表一样,视图包含一系列带有名称的列和行数据。但是,视图并不在数据库中以存储的数据值集形式存在。行和列数据来自由定义视图的查询所引用的表,并且在引用视图时动态生成

视图和表的区别

  • 视图是一张虚拟表,不是真实的表。结构和数据是建立在对数据中真实表的基础上
  • 存储在数据库中的查询操作SQL语句定义了视图的内容,列数据和行数据来自于视图查询所引用的实际表,引用视图时动态生成这些数据
  • 视图没有实际的物理记录,不是以数据集的形式存储在数据库中的,所对应的数据实际是存储在视图所引用的 真实表中
  • 视图是数据的窗口,表是内容。表是实际数据存放的单位,而视图只是以不同的显示方式展示数据源,其数据来源还是表
  • 视图是查看表的一种方法,可以查询数据表中某些字段构成的数据,只是一些SQL语句的集合。从安全角度来看,视图的安全性更高,使用视图的用户不接触数据表,不知道结构
  • 视图的建立和删除只影响视图本身,不影响对应的基本表

使用视图优点

定制用户数据,聚焦定制的数据

在实际的应用中,不同的用户对不同的数据有不同的要求。例如,当数据库同时存在时,如学生基本信息表、课程表和教师信息表等多种表同时存在时,可以根据需求让不同的用户使用各自的数据。学生查看修改自己基本信息的视图,安排课程人员查看修改课程表和教师信息的视图,教师查看学生信息和课程信息表的视图。

简化数据操作

在使用查询时,很多时候要使用聚合函数,同时还要显示其他字段的信息,可能还需要关联到其他表,语句可能会很长,如果这个动作频繁发生的话,可以创建视图来简化操作

提高基表数据的安全性

视图是虚拟的,物理上是不存在的。可以只授予用户视图的权限,而不具体指定使用表的权限,来保护基础数据的安全

共享所需数据

通过使用视图,每个用户不必都定义和存储自己所需的数据,可以共享数据库中的数据,同样的数据只需要存储一次

更改数据格式

通过使用视图,可以重新格式化检索出的数据,并组织输出到其他应用程序中

重用 SQL 语句

视图提供的是对查询操作的封装,本身不包含数据,所呈现的数据是根据视图定义从基础表中检索出来的,如果基础表的数据新增或删除,视图呈现的也是更新后的数据。视图定义后,编写完所需的查询,可以方便地重用该视图

使用注意事项

  • 创建视图需要足够的访问权限
  • 创建视图的数目没有限制
  • 视图可以嵌套,即从其他视图中检索数据的查询来创建视图
  • 视图不能索引,也不能有关联的触发器、默认值或规则
  • 视图可以和表一起使用
  • 视图不包含数据,所以每次使用视图时,都必须执行查询中所需的任何一个检索操作。如果用多个连接和过滤条件创建了复杂的视图或嵌套了视图,可能会发现系统运行性能下降得十分严重。因此,在部署大量视图应用时,应该进行系统测试

使用操作

创建视图
create view 视图名 as select语句
调用视图
SELECT * FROM 视图名
删除视图
drop view if esists 视图名
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值