前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >第八章《视图》

第八章《视图》

作者头像
全栈程序员站长
发布2022-06-29 15:47:19
2890
发布2022-06-29 15:47:19
举报
文章被收录于专栏:全栈程序员必看

视图:视图(view)是一种虚拟存在的表,是一个逻辑表,本身并不包括数据 作为一个select语句保存在数据字典中的 通过视图,可以展现基表的部分数据,属兔数据来自定义视图的查询中使用的表 使用视图动态生成 基表:用来创建视图的表叫做基表base table 因为试图的诸多优点 如下: 1)简单:使用视图的用户完全不需要关心后面对应的表的结构、关联条件和筛选条件,对用户来说已经是过滤好的复合条件的结果集。 2)安全:使用视图的用户只能访问他们被允许查询的结果集,对表的权限管理并不能限制到某个行某个列,但是通过视图就可以简单的实现。 3)数据独立:一旦视图的结构确定了,可以屏蔽表结构变化对用户的影响,源表增加列对视图没有影响;源表修改列名,则可以通过修改视图来解决,不会造成对访问者的影响。

总而言之,使用视图的大部分情况是为了保障数据安全性,提高查询效率。

视图是一张虚拟表,和真实的表一样包含一系列带有名称的行和列数据,视图是从一个或多个表中导出来的数据的结构,我们可以通过DML语句(insert,update,delete)来操作视图当中的数据,当视图当中的数据被修改时,基表当中的数据据也会被修改,反之也一样。

创建视图:a CREATE [OR REPLACE] [ALGORITHM=UNDEFINED|MERGE|TEMPTABLE] VIEW 视图名称[(视图字段名)] AS select_statement [WHITH[CASCADED|LOCAL] CHECK OPTION]

OR REPLACE:用于修改已经创建好的视图的结构(如果视图不存在,那就创建视图);

ALGORITHM:选择select语句运算方法

UNDEFINED:mysql自动选择算法

MERGE;合并,表示将视图设置的字段名称和select语句从表中获取的字段的内容合并

TEMPTABLE:临时表,表示将视图的结果存入临时表,然后用临时表来执行语句

column_list:定义的视图当中的字段名称

select_statement: 查询语句

WITH [CASCADED|LOCAL] CHECK OPTION;

CASCADED:默认为CASCADED,表示更新视图时,需要满足所有相关视图和表的条件限制

LOCAL:表示更新视图时,满足该视图本身定义的条件即可;

查看视图结构 desc 表名; show create view 表名\G;

创建book表

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

创建视图

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

查看视图内容

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

查看视图结构 desc 表名; show create view 表名\G;

创建视图创建table1表

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

用fruits和suppliers做

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

查看视图详细的信息; (1)show create view 视图名\G 在mysql当中,视图的信息存储在information schema数据库下的views表中 select * from information_schema.views\G;

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

修改视图; create or replace view 视图名 as select 。。。

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

更新视图: 1.update

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

修改视图,基表里面对应的数据也会被修改,反之相同 2.insert

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

3.delec

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

视图存在一下情况时,更新操作无效: 1.视图中不包含基表中被定义为非空的列 2.在定义视图的select语句后的字段列使用了数学表达式 3.在定义视图select语句里使用了聚合函数(count,max,min) 4.select语句中,使用了union、group by、order、having。 如果视图包含下述结构中的任何一种,那么它就是不可更新的:

(1)聚合函数;

(2)DISTINCT关键字;

(3)GROUP BY子句;

(4)ORDER BY子句;

(5)HAVING子句;

(6)UNION运算符;

(7)位于选择列表中的子查询;

(8)FROM子句中包含多个表;

(9)SELECT语句中引用了不可更新视图;

(10)WHERE子句中的子查询,引用FROM子句中的表;

(11)ALGORITHM 选项指定为TEMPTABLE(使用临时表总会使视图成为不可更新的)。

删除视图 DROP VIEW 视图名 删除视图不会影响到基表

mysq中视图和表的区别以及联系: 两者的区别: (1)视图是已经编译好的SQL语句的结果集,是基于SQL语句结果集的可视化的表,而表不是; (2)视图没有实际的物理记录,而表有; (3)表是内容,视图是窗口; (4)表和视图碎岩都占用物理空间,但是视图只是逻辑概念存在; (5)视图是查看表数据的一-种方法,可以查询数据表中某些字段构成的数据,只是- -些SQL语句的 集合。从安全角度来说,视图可以防止用户接触数据表,因而不知道表结构; (6)表属于全局模式的表,是实表。视图属于局部模式的表,是虚表; (7)视图的建立和删除值影响视图本身,而不影响对应的基本表;

两者的联系: 试图使在基本表之上建立的表,他的结构和内容都来自于基本表,它依赖基本表存在而存在,一个视图可以对应一个基本表或多个。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/101970.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021年5月2,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档