第八章《视图》

第八章《视图》

视图:视图(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.net/101970.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 数论 欧拉函数_数论欧拉函数

    数论 欧拉函数_数论欧拉函数欧拉函数:就是对于一个正整数n,小于n且和n互质的正整数(包括1)的个数,记作φ(n)。欧拉函数的通式:φ(n)=n*(1-1/p1)(1-1/p2)(1-1/p3)*(1-1/p4)……(1-1/pn)其中p1,p2……pn为n的所有质因数,n是不为0的整数。φ(1)=1(唯一和1互质的数就是1本身)。所以,根据通式我们可以打出以下代码:lleular(lln){…

    2022年8月22日
    6
  • 单射、双射、满射

    单射、双射、满射映射就是说对于集合X里的每一个元素x,按法则f,在集合Y里都有唯一的y与之对应,那么称f为从集合X到集合Y的映射。记作f:X->Y。映射基本要求是1.对于X中的每一个x,都有对应的y,还有2.一个x,只能有一个唯一的y与之对应。按照其他限制条件不同,可分为以下3种:单射:满足,对于不同的x,经过映射后的y不同。即当x1!=x2,f(x1)!==f(x2)。满足单射的映射可以不满足满射,例如,我们将一个满足单射的映射f的值域放大,此时有y没有x与之对应。满射:满足,Y集

    2022年6月10日
    109
  • linux安装gcc命令步骤(centos安装gcc命令)[通俗易懂]

    linux安装gcc命令步骤(centos安装gcc命令)[通俗易懂]linux安装gcc命令步骤(centos安装gcc命令)>一、前言本文介绍在CentOS7.8系统下使用YUM升级GCC版本的相关操作步骤。CentOS7默认安装的gcc版本是4.8版本,gcc4.8最主要的一个特性就是全面支持C++11,如果不清楚什么用的也没关系,简单说一些C++11标准的程序都需要gcc4.8以上版本的gcc编译器编译。很多工具依赖的是更高版本的gcc,比如编译MySQL8.0(8.0.16以上版本是C++14标准,需gcc5.3以上版本)、Redis6.

    2022年10月10日
    4
  • JS判断页面是否刷新

    JS判断页面是否刷新判断页面刷新的方式用到了 NavigationTi 这个属性主要是为了评估网站的表现 比如网页加载时间 发送与获取请求的时间 网页渲染时间等等 checkforNavi window performance console info window performancew

    2025年8月4日
    3
  • 不止编码,还要好好生活和思考[通俗易懂]

    做一个积极的人编码、改bug、提升自己我有一个乐园,面向编程,春暖花开!2019年4月最后一天,不写技术,谈谈我的乐园,我喜欢的一首诗,分享给你!面朝大海,春暖花开[作者] 海子从明天起,做一个幸福的人喂马,劈柴,周游世界从明天起,关心粮食和蔬菜我有一所房子,面朝大海,春暖花开从明天起,和每一个亲人通信告诉他们我的幸福那幸福的闪电告诉我的我将告诉每一个人给每一条河…

    2022年3月1日
    46
  • MyBatis标签详解

    MyBatis标签详解MyBatis标签详解

    2022年4月22日
    68

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号