MYSQL学习路线(4)

视图

视图是从一个或几个基本表(或视图)导出的表。它与基本表不同,是一个虚表。数据库中只存放视图的定义,而不存放视图对应的数据,这些数据仍存放在原来的基本表中。所以一旦基本表中的数据发生变化,从视图中查询出的数据也就随之改变了。从这个意义上讲,视图就像一个窗口,透过它可以看到数据库中自己感兴趣的数据及其变化。

视图一经定义,就可以和基本表一样被查询、被删除。也可以在一个视图之上再定义新的视图,但对视图的更新(增、删、改)操作则有一定的限制。

1、定义视图

建立视图:

/*格式*/
CREATE VIEW <视图名> [(<列名>[,<列名>]...)]
AS <子查询>
[WITH CHECK OPTION];

其中,子查询可以是任意的SELECT语句,是否可以含有OEDER BY子句和DISTINCT短语,则取决于具体系统的实现。

WITH CHECK OPTION表示对视图进行UPDATE、INSERT和DELETE操作时要保证更新、插入或删除的行满足视图定义中的谓词定义(即子查询中的条件表达式)。

组成视图的属性列名或者全部省略或者全部指定,没有第三种选择。如果省略了视图的各个属性列名,则隐含该视图由子查询中SELECT子句目标列中的诸字段组成。但在下列三种情况下必须明确指定组成视图的所有列名:

  1. 某个目标列不是单纯的属性名,而是聚集函数或者列表达式;
  2. 多个连接时选出了几个同名列作为视图的字段;
  3. 需要在视图中为某个列启用新的更适合的名字。

问题:建立信息系学生的视图

CREATE VIEW IS_Student
AS
SELECT Sno,Sname,Sage
FROM Student
WHERE Sdept='IS';

问题:建立信息系学生的视图,并要求进行修改和插入操作时仍需保证该视图只有信息系的学生。

CREATE VIEW IS_Student
AS
SELECT Sno,Sname,Sage
FROM Student
WHERE Sdept='IS'
WITH CHECK OPTION;

由于在定义IS_Student视图时加上了WITH CHECK OPTION子句,以后对该视图进行插入、修改和删除操作时,关系数据库管理系统会自动加“ Sdept='IS' ”的条件。

问题:建立信息系选修了1号课程的学生的视图(包括学号、姓名、成绩)。

CREATE VIEW IS_SI(Sno,Sname,Grade)
AS
SELECT Student.Sno,Sname,Grade
FROM Student,SC
WHERE Sdept='IS' AND Student.Sno=SC.Sno AND SC.Cno='1';

删除视图:

/*格式*/
DROP VIEW <视图名>[CASCADE];

视图删除后视图的定义将从数据字典中删除。如果该视图上还导出了其他视图,则使用CASCADE级联删除语句把该视图和由它导出的所有视图一起删除。

基本表删除后,由该基本表导出的所有视图均无法使用了,但是视图的定义没有从字典中清除。删除这些视图定义需要显式地使用DROP VIEW语句。

2、查询视图

视图定义后,用户就可以像对基本表一样对视图进行查询。

关系数据库管理系统执行对视图的查询时,首先进行有效性检查,检查查询中涉及的表、视图等存在。如果存在,则从数据字典中取出视图的定义,把定义中的子查询和用户的查询结合起来,转换成等价的对基本表的查询,然后再执行修正了的查询。这一过程称为视图消解

/*案例1*/
SELECT Sno,Sage
FROM IS_Student
WHERE Sage<20;


/*案例2*/
SELECT Sno,AVG(Sage)
FROM IS_Student
GROUP BY Sno
HAVING AVG(Grade)>=90;

/*案例3,派生表*/
SELECT *
FROM(SELECT Sno,AVG(Sage)
     FROMIS_Student
     GROUP BY Sno) AS S_G(Sno,Sg)
WHERE Sg>=90;

定义视图并查询视图与基于派生表的查询是有区别的。视图一旦定义,其定义将永久保存在数据字典中,之后的所有查询都可以直接引用该视图。而派生表只是语句执行时临时定义,语句执行后该定义即被删除。

3、更新视图

更新视图是指通过视图插入(INSERT)、删除(DELETE)和修改(UPDATE)数据。

由于视图是不实际存储数据的虚表,因此对视图的更新最终要转换为对基本表的更新。像查询视图那样,对视图的更新操作也是通过视图消解,转换为对基本表的更新操作。

为防止用户通过视图对数据进行增加、删除、修改时,有意无意地对不属于视图范围内的基本表数据进行操作,可在定义视图时加上WITH CHECK OPTION子句。这样在视图上增、删、改数据时,关系数据库管理系统会检查视图定义中的条件,若不满足条件则拒绝执行该操作。

问题:将信息系学生视图IS_Student中学号为"201215122"的学生姓名改为“刘晨”

UPDATE IS_Student
SET Sname='刘晨'
WHERE Sno='201215122';
/*转换后的更新语句*/
UPDATE Student
SET Sname='刘晨'
WHERE Sno='201215122' AND Sdept='IS';/*定义视图时,加上了WITH CHECK OPTION的原因*/

DB2规定:

  1. 若视图是由两个以上基本表导出的,则此视图不允许更新。
  2. 若视图的字段来自字段表达式或常数,则不允许对此视图执行INSERT和UPDATE操作,但允许执行DELETE操作。
  3. 若视图的字段来自聚集函数,则此视图不允许更新。
  4. 若视图定义中含有GROUP BY子句,则此视图不允许更新。
  5. 若视图定义中含有DISTINCT短语,则此视图不允许更新。
  6. 若视图定义中有嵌套查询,并且内层查询的FROM子句中涉及的表也是导出该视图的基本表,则此视图不允许更新。
  7. 一个不允许更新的视图上定义的视图也不允许更新。

4、视图的作用

视图最终是定义在基本表之上的,对视图的一切操作最终也要转换为对基本表的操作。而且对于非行列子集视图进行查询或更新时还有可能出现问题。既然如此,为何还要定义视图呢?好处如下:

  1. 视图能够简化用户的操作。
  2. 视图使用户能以多种角度看待同一数据。
  3. 视图对重构数据库提供了一定程度的逻辑独立性。
  4. 视图能够对机密数据提供安全保护。
  5. 适当利用视图可以更清晰地表达查询。例如:经常需要执行这样的查询“对每个同学找出他获得最高成绩的课程号”。可以先定义一个视图,求出每个同学获得的最高成绩。

------>>数据库的使用与连接《MYSQL学习路线(5)》

 

你可能感兴趣的:(数据库)