1月阅读周·MySQL数据库入门:视图之在多表上创建视图&删除视图篇
背景
去年下半年,我在微信书架里加入了许多技术书籍,各种类别的都有,断断续续的读了一部分。
没有计划的阅读,收效甚微。
新年伊始,我准备尝试一下其他方式,比如阅读周。每月抽出1~2个非连续周,完整阅读一本书籍。
这个“玩法”虽然常见且板正,但是有效,已经坚持阅读十二个月。
已读完书籍:《架构简洁之道》、《深入浅出的Node.js》、《你不知道的JavaScript(上卷)》、《你不知道的JavaScript(中卷)》、《你不知道的JavaScript(下卷)》、《数据结构与算法JavaScript描述》、《WebKit技术内幕》、《前端架构:从入门到微前端》、《秒懂算法:用常识解读数据结构与算法》、《JavaScript权威指南》、《JavaScript异步编程设计快速响应的网络应用》、《编写可测试的JavaScript代码》。
当前阅读周书籍:《MySQL数据库入门》。
视图概述
视图是从一个或多个表中导出来的表,它是一种虚拟存在的表,并且表的结构和数据都依赖于基本表。通过视图不仅可以看到存放在基本表中的数据,并且还可以像操作基本表一样,对视图中存放的数据进行查询、修改和删除。与直接操作基本表相比,视图具有以下优点。
1.简化查询语句
视图不仅可以简化用户对数据的理解,也可以简化对数据的操作。日常开发中可以将经常使用的查询定义为视图,从而使用户避免大量重复的操作。
2.安全性
通过视图用户只能查询和修改他们所能见到的数据,数据库中的其他数据则既看不到也取不到。数据库授权命令可以使每个用户对数据库的检索限制到特定的数据库对象上,但不能授权到数据库特定行和特定的列上。
3.逻辑数据独立性
视图可以帮助用户屏蔽真实表结构变化带来的影响。
综上所述,在操作数据库时,由于视图是在基本表上建立的表,它的结构和数据都来自于基本表,因此,诸如更新数据等操作,都可以在视图上进行。
在多表上创建视图
在MySQL中除了可以在单表上创建视图,还可以在两个或者两个以上的基本表上创建视图。本篇将通过具体的案例来讲解如何在多表上创建视图。
【例1-1】 在student表和stu_info表上创建stu_class视图,查询出s_id号、姓名和班级,具体步骤如下。
(1)首先创建stu_info表,创建stu_info表的SQL语句如下所示:
mysql>CREATE TABLE stu_info(
->s_id INT(3),
->class VARCHAR(50),
->addr VARCHAR(100)
->);
使用INSERT语句向stu_info表中插入数据,SQL语句如下所示:
INSERT INTO stu_info(s_id,class,addr) VALUES (1,'erban','anhui');
INSERT INTO stu_info(s_id,class,addr) VALUES (2,'sanban','chongqing');
INSERT INTO stu_info(s_id,class,addr) VALUES (3,'yiban','shandong');
在上述SQL语句执行成功后,会在stu_info表中添加三条数据。为了验证数据是否添加成功,使用SELECT语句查询stu_info表,查询结果如下所示:
mysql>SELECT * FROM stu_info;
+------+--------+-----------+
| s_id | class | addr |
+------+--------+-----------+
| 1 | erban | anhui |
| 2 | sanban | chongqing |
| 3 | yiban | shandong |
+------+--------+-----------+
3 rows in set (0.00 sec)
从查询结果可以看出,stu_info表中成功地添加了三条记录。
(2)创建stu_class视图,SQL语句如下所示:
CREATE VIEW stu_class(id,name,glass)
AS
SELECT student.s_id ,student.name,stu_info.class
FROM student,stu_info
WHERE student.s_id=stu_info.s_id;
上述SQL语句执行成功后,会生成一个名为stu_class的视图,接下来使用SELECT语句查看view_stu2视图,查询结果如下所示:
mysql>SELECT * FROM stu_class;
+----+------+--------+
| id | name | class |
+----+------+--------+
| 1 | Tom | erban |
| 2 | Jack | sanban |
| 3 | Lucy | yiban |
+----+------+--------+
3 rows in set (0.06 sec)
从执行结果可以看出,创建的视图中包含id、name和class字段,其中,id字段对应student表中的s_id字段,name对应student表中的name字段,class字段对应sut_info表中的class字段。
删除视图
当视图不再需要时,可以将其删除,删除视图时,只能删除视图的定义,不会删除数据。删除一个或多个视图可以使用DROP VIEW语句,删除视图的基本语法格式如下所示:
DROP VIEW[IF EXISTS]
view_name [,view_name1]…
[RESTRICT | CASCADE]
在上述语法格式中,view_name是要删除的视图的名称,视图名称可以添加多个,各个名称之间使用逗号隔开,删除视图必须拥有DROP权限。
【例1-1】 删除view_stu2视图。SQL语句如下所示:
DROP VIEW IF EXISTS view_stu2;
上述SQL语句执行成功后,会将view_stu2视图删除。为了验证视图是否删除成功,使用SELECT语句查看view_stu2视图,查询结果如下所示:
mysql>SELECT * FROM view_stu2;
ERROR 1146 (42S02): Table 'chapter07.view_stu2' doesn't exist
从上述查询结果可以看出,查询结果显示view_stu2视图不存在,说明视图被成功删除。
总结
视图具有简化查询语句、安全性和保证逻辑数据独立性等作用,掌握如何管理视图是非常重要的。
在MySQL中除了可以在单表上创建视图,还可以在两个或者两个以上的基本表上创建视图。
当视图不再需要时,可以将其删除,删除视图时,只能删除视图的定义,不会删除数据。删除一个或多个视图可以使用DROP VIEW语句。
作者介绍
非职业「传道授业解惑」的开发者叶一一。
《趣学前端》、《CSS畅想》等系列作者。华夏美食、国漫、古风重度爱好者,刑侦、无限流小说初级玩家。
如果看完文章有所收获,欢迎点赞👍 | 收藏⭐️ | 留言📝。
- 点赞
- 收藏
- 关注作者
评论(0)