什么是视图

数据库中的视图是一个虚拟表。视图是从一个或者多个表中导出的表,视图的行为与表非常相似,在视图中用户可以使用SELECT语句查询数据,以及使用INSERT、UPDATE和DELETE修改记录。视图可以使用户操作方便,而且可以保障数据库系统安全。

视图一经定义便存储在数据库中,预期相对应的数据并没有像表那样在数据库中再存储一份,通过视图看到的数据只是存放在基本表中的数据。当对通过视图看到的数据进行修改时,相应的基本表中的数据也要发生变化;同时,若基本表的数据发生变化,那么这种变化也自动地反映到视图中。

下面创建两个表:

CREATE TABLE teacher
(
teacherId INT,
teacherName VARCHAR(40)
); CREATE TABLE teacherinfo
(
teacherId INT,
teacherAddr VARCHAR(40),
teacherPhone VARCHAR(20)
);

创建视图

创建视图使用CREATE VIEW语法,基本语法格式如下:

CREATE[OR REPLACE] [ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}]
VIEW view_name [(column_list)]
AS SELECT_statement
[WITH [CASCASDED | LOCAL] CHECK OPTION]

解释一下:

1、CREATE表示创建新视图。REPLACE表示替换已经创建的视图

2、ALGORITHM表示视图选择的算法,UNDEFINED表示MySQL自动选择算法,MERGE表示将使用的视图语句与视图定义合并起来,TEMPTABLE表示将视图的结果存入临时表,然后用临时表来执行语句

3、view表示视图的名称

4、column_list为属性列

5、SELECT_statement表示SELECT语句

6、CASCADED与LOCAL为可选参数,CASCADED为默认值,表示更新视图时要满足所有相关视图和表的条件;LOCAL则表示更新视图时满足该视图本身定义即可

该语句要求具有针对视图的CREATE VIEW权限,以及针对由SELECT语句选择的每一列上的某些权限。对于在SELECT语句中其他地方使用的列,必须具有SELECT权限,如果还有OR REPLACE子句,必须在仕途上具有DROP权限。另外,视图属于数据库,在默认情况下,将在当前数据库创建新的视图,如果想在给定数据库中明确创建视图,创建时应将名称指定为db_name.view_name。

1、在单表上创建视图

比方说teacherinfo这张表我只需要teacherId和teacherPhone两个字段,那么:

CREATE VIEW view_teacherinfo(view_teacherId, view_teacherPhone)
AS SELECT teacherId, teacherPhone from teacherinfo;

因为默认创建视图的字段和原表的字段是一样的,我这里指定视图的字段名称了。我现在往view_teacherinfo里面插入两个字段:

insert into view_teacherinfo values('', '');
commit;

看一下视图view_teacherinfo和原表teacherinfo:

说明视图中的字段发生变化,原表中的字段也发生了变化,证明了前面的结论,反之也是。

2、在多表上创建视图

比方说我现在需要teacherId、teacherName、teacherPhone三个字段了,可以这么创建视图:

CREATE VIEW view_teacherunion(view_teacherId, view_teacherName, view_teacherPhone)
AS SELECT teacher.teacherId, teacher.teacherName, teacherinfo.teacherPhone
FROM teacher, teacherinfo WHERE teacher.teacherId = teacherinfo.teacherId;

很简单,只是把表连一下而已

使用视图的作用

上面创建了视图了,看到与直接从数据表中读取相比,视图有以下优点:

1、简单化

看到的就是需要的。视图不仅可以简化用户对数据的理解,也可以简化它们的操作。那些被经常使用的查询可以被定义为视图,从而使得用户不必为以后的操作每次指定全部的条件

2、安全性

通过视图,用户只能查询和修改他们所能看见的数据,数据库中的其他数据则既看不见也取不到。数据库授权命令可以使每个用户对数据库的检索限制到特定的数据库对象上,但不能授权到数据库特定行和特定列上。通过视图,用户可以被限制在数据的不同子集上:

(1)使用权限可被限制在基表的行的子集上

(2)使用权限可被限制在基表的列的子集上

(3)使用权限可被限制在基表的行和列的子集上

(4)使用权限可被限制在多个基表的连接所限定的行上

(5)使用权限可被限制在基表的数据的统计汇总上

(6)使用权限可被限制在另一个视图的一个子集上,或是一些视图和基表合并后的子集上

3、逻辑数据独立性

视图可以帮助用户屏蔽真实表结果变化带来的影响

查看、修改、删除视图

1、DESCRIBE查看视图基本信息

DESCRIBE语句查看视图基本信息的语法为:

DESCRIBE 视图名;

比如:

DESCRIBE view_teacherinfo

结果为:

结果显示出来视图的字段定义、字段的数据类型、是否为空、是否为主/外键、默认值和额外信息。上面的命令,写成DESC也行

2、SHOW TABLE STATUS查看视图信息

SHOW TABLE STATUS也可以用来查看视图信息,基本语法为:

SHOW TABLE STATUS LIKE '视图名'

比如:

SHOW TABLE STATUS LIKE 'view_teacherinfo'

结果为:

后面还有些字段就不列出来了

3、SHOW CREATE VIEW查看视图信息

SHOW CREATE VIEW也可以用来查看视图信息,基本语法为:

SHOW CREATE VIEW 视图名;

比如:

SHOW CREATE VIEW view_teacherinfo;

运行结果为:

没有列完整,不过可以看到Create View字段把创建视图的语法给列出来了

4、修改视图

修改视图,就不细说了,因为修改视图的语法和创建视图的语法是完全一样的。当视图已经存在时,修改语句可以对视图进行修改;当视图不存在时,创建视图

5、删除视图

当视图不再需要时,可以删除视图,删除一个或者多个视图可以使用DROP VIEW语句,基本语法为:

DROP VIEW [IF EXISTS]
view_name [, view_name] ...
[RESTRICT | CASCADE]

其中,view_name是要删除的视图名称,可以添加多个需要删除的视图名称,名称和名称之间使用逗号分隔开,删除视图必须拥有DROP权限。比如:

DROP VIEW IF EXISTS view_teacherinfo, view_teacherunion;

看到,这样就把view_teacherinfo和view_teacherunion两个视图删除了,因为加了IF EXISTS,所以即使删除视图出错了(比方说视图名字写错了),MySQL也不会提示错误,大不了没东西删除罢了

MySQL中视图和表的区别

最后总结一下MySQL中视图和表的区别:

1、视图是已经编译好的SQL语句,是基于SQL语句的结果集的可视化的表,而表不是

2、视图没有实际的物理记录,而基本表有

3、表是内容,视图是窗口

4、表占用物理空间而视图不占用物理空间,视图只是逻辑概念的存在,表可以及时对它进行修改,但视图只能用创建的语句来修改

5、视图是查看数据表的一种方法,可以查询数据表中的某些字段构成的数据,只是一些SQL语句的集合。从安全的角度讲,视图可以防止用户接触数据表,因而用户不知道表结构

6、表属于全局模式中的表,是实表;视图属于局部模式的表,是虚表

7、视图的建立和删除只影响视图本身,不影响对应的基本表

MySQL7:视图的更多相关文章

  1. ASP.NET MVC with Entity Framework and CSS一书翻译系列文章之第二章:利用模型类创建视图、控制器和数据库

    在这一章中,我们将直接进入项目,并且为产品和分类添加一些基本的模型类.我们将在Entity Framework的代码优先模式下,利用这些模型类创建一个数据库.我们还将学习如何在代码中创建数据库上下文类 ...

  2. ASP.NET Core 中文文档 第四章 MVC(3.8)视图中的依赖注入

    原文:Dependency injection into views 作者:Steve Smith 翻译:姚阿勇(Dr.Yao) 校对:孟帅洋(书缘) ASP.NET Core 支持在视图中使用 依赖 ...

  3. 在WPF中使用依赖注入的方式创建视图

    在WPF中使用依赖注入的方式创建视图 0x00 问题的产生 互联网时代桌面开发真是越来越少了,很多应用都转到了浏览器端和移动智能终端,相应的软件开发上的新技术应用到桌面开发的文章也很少.我之前主要做W ...

  4. ABP文档 - Mvc 视图

    文档目录 本节内容: 简介 AbpWebViewPage 基类 简介 ABP通过nuget包Abp.Web.Mvc集成到Mvc视图里,你可以像往常那样创建常规的视图. AbpWebViewPage 基 ...

  5. 探索ASP.NET MVC5系列之~~~2.视图篇(上)---包含XSS防御和异步分部视图的处理

    其实任何资料里面的任何知识点都无所谓,都是不重要的,重要的是学习方法,自行摸索的过程(不妥之处欢迎指正) 汇总:http://www.cnblogs.com/dunitian/p/4822808.ht ...

  6. 探索ASP.NET MVC5系列之~~~3.视图篇(下)---包含常用表单和暴力解猜防御

    其实任何资料里面的任何知识点都无所谓,都是不重要的,重要的是学习方法,自行摸索的过程(不妥之处欢迎指正) 汇总:http://www.cnblogs.com/dunitian/p/4822808.ht ...

  7. SQL Server-聚焦在视图和UDF中使用SCHEMABINDING(二十六)

    前言 上一节我们讨论了视图中的一些限制以及建议等,这节我们讲讲关于在UDF和视图中使用SCHEMABINDING的问题,简短的内容,深入的理解,Always to review the basics. ...

  8. SQL Server-聚焦使用视图若干限制/建议、视图查询性能问题,你懵逼了?(二十五)

    前言 上一节我们简单讲述了表表达式的4种类型,这一系列我们来讲讲使用视图的限制,简短的内容,深入的理解,Always to review the basics. 避免在视图中使用ORDER BY 上一 ...

  9. MySQL 系列(三)你不知道的 视图、触发器、存储过程、函数、事务、索引、语句

    第一篇:MySQL 系列(一) 生产标准线上环境安装配置案例及棘手问题解决 第二篇:MySQL 系列(二) 你不知道的数据库操作 第三篇:MySQL 系列(三)你不知道的 视图.触发器.存储过程.函数 ...

随机推荐

  1. 用TypeScript开发爬虫程序

    全局安装typescript: npm install -g typescript 目前版本2.0.3,这个版本不再需要使用typings命令了.但是vscode捆绑的版本是1.8的,需要一些配置工作 ...

  2. Flask备注三(Context)

    Flask备注三(Context) Flask支持不同的应用场景下,对应不同的local context(本地上下文环境),用来提供当前环境下的资源.lcoal context和全局变量以及局部变量最 ...

  3. final

    final的变量的值不能被改变.(包括形参) final的方法不能被重写. final的类不能被继承.

  4. 创建nim+安装vioc分区

    一.搭建nim服务器 1.安装须知 安装nim软件包,client随系统默认安装,这里需要安装的是bos.sysmgt.nim.master和bos.sysmgt.nim.spot,即bos.sysm ...

  5. python day2 字符串的方法

    1.首字母大写 name = "wuyuchao"result = name.capitalize()print(result)返回 Wuyuchao--------------- ...

  6. 【Java学习笔记】静态导入

    package p2; //import static java.util.Collections.max; import java.util.ArrayList; import static jav ...

  7. Java学习笔记 04 类和对象

    一.类和对象的概念 类 >>具有相同属性和行为的一类实体 对象 >>实物存在的实体.通常会将对象划分为两个部分,即静态部分和动态部分.静态部分指的是不能动的部分,被称为属性,任 ...

  8. Head First 设计模式读书笔记

    在网上学习了一段时间设计模式,总感觉不系统,很容易忘,最近买书,学习了<Head First设计模式>,受益匪浅,特做此记录,以便激励自己不断的向后学习. 原书JAVA版本,本次学习记录及 ...

  9. ASP.NET Core 1.0 入门——了解一个空项目

    var appInsights=window.appInsights||function(config){ function r(config){t[config]=function(){var i= ...

  10. 『TCP/IP详解——卷一:协议』读书笔记——10

    2013-08-22 22:57:17 3.8 ifconfig命令 这个命令在Linux系统下可以通过下面的指令阅读说明文档: ifconfig 由于书中作者用的系统比较早的某Unix系统,所以我的 ...