MySQL——视图的介绍

Posted 铁甲小宝同学

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL——视图的介绍相关的知识,希望对你有一定的参考价值。

前言

本节内容来源于数据库系统概论(第五版)王珊,萨师煊编著!

本节内容是由于今天我上数据库课的时候对视图的一直有一个疑问——视图和表的查询一样,为什么用户不直接使用表,还要在建一个视图?因为这个问题,我就从书上寻找,带着疑问我是寻找到我想要的答案,而且我还把视图给大概的分类,然后我就写了这篇博客!!希望能帮助大家!!!

目录

1.视图的介绍

2.视图的作用 

3.定义视图

①建立视图

视图格式 

 列子集视图:

多种视图: 

②删除视图

4.查询视图

5.更新视图


1.视图的介绍

首先我们需要直到视图是什么???

答:视图是从一个表或者几个表(或视图)导出的表。它于基本表不同,是一个虚表。数据库中只存放视图的定义,而不存放视图对应的数据,这些数据仍存放在原来的基本表中。所以一旦基本表中的数据发生变化,从视图中查询的出的数据也就随之改变。


 

2.视图的作用 

①视图能简化用户的操作。
②视图能以多种角度看待同一数据。
③视图对重构数据库提供了一定程度的逻辑独立性。
④视图能够对机密数据提供安全保护。
⑤适当利用视图可以更清晰地表达查询。

3.定义视图

①建立视图

视图格式 

SQL语言用create view 命令建立视图,其一般格式为:

create view<视图名>[(<列名>[,<列名>]...)]
as <子查询>
with check option;

 其中,子查询可以是任意的select语句,是否可以含有 order by 子句和 distinct短语,则取决于具体的系统实现。

with check option 表示对视图进行updat,insert,delete操作时要保证更新,插入或删除的行满足视图定义的谓词条件(即子查询中的条件表达式)。

注意:组成视图的属性列名或者全部省略或者全部指定,没有第三种选择。

以下三种情况必须明确指定组成视图的所有列名:

某个目标列是聚集函数或列表达式
多表连接时选出了几个同名列作为视图的字段
需要在视图中为某个列启用新的更合适的名字

 

关系数据库管理系统执行CREATE VIEW语句时只是把视图定义存入数据字典,并不执行其中的SELECT语句。 

 

 列子集视图:

 若一个视图是从单个基本表导出的,并且只是去掉了基本表的某些行和某些列,但保留了主码,我们称这类视图为行列子集视图

多种视图: 

多个表的视图: 

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

 基于视图的视图

 

CREATE VIEW IS_S2
        AS
        SELECT Sno,Sname,Grade
        FROM  IS_S1
        WHERE  Grade>=90;

带表达式的视图 

CREATE  VIEW BT_S(Sno,Sname,Sbirth)
        AS 
        SELECT Sno,Sname,2014-Sage
        FROM  Student;

 分组视图

CREAT  VIEW S_G(Sno,Gavg)
             AS  
             SELECT Sno,AVG(Grade)
             FROM  SC
             GROUP BY Sno;

 

②删除视图

语句的格式: 

DROP  VIEW  <视图名>[CASCADE];

该语句从数据字典中删除指定的视图定义。

如果该视图上还导出了其他视图,使用CASCADE级联删除语句,把该视图和由它导出的所有视图一起删除。

删除基表时,由该基表导出的所有视图定义都必须显式地使用DROP VIEW语句删除。 

要删除IS_S1,需使用级联删除:            

DROP VIEW IS_S1 CASCADE;  

 

4.查询视图

视图定义后,用户就可以向对基本表一样的对视图经行查询了。 

用户角度:查询视图与查询基本表相同 

 

 什么是视图消解??

我们用下面三句话直接概括!!! 

进行有效性检查。
转换成等价的对基本表的查询。
执行修正后的查询。

[例]  在信息系学生的视图中找出年龄小于20岁的学生。

       SELECT   Sno,Sage
       FROM      IS_Student
       WHERE   Sage<20;

视图消解转换后的查询语句为

 SELECT  Sno,Sage       
 FROM  Student
 WHERE  Sdept= 'IS'  AND  Sage<20;

视图消解法的局限 

有些情况下,视图消解法不能生成正确的查询。

在S_G视图中查询平均成绩在90分以上的学生学号和平均成绩

SELECT *
FROM   S_G
WHERE  Gavg>=90;

 S_G视图的子查询定义:

CREATE VIEW S_G (Sno,Gavg)
            AS 
SELECT  Sno,AVG(Grade)
FROM  SC
GROUP BY Sno;

错误:

SELECT Sno,AVG(Grade)
FROM     SC
WHERE  AVG(Grade)>=90
GROUP BY Sno;

 正确:

SELECT  Sno,AVG(Grade)
FROM  SC
GROUP BY Sno
HAVING AVG(Grade)>=90;

 


5.更新视图

更新视图是指通过视图又 来插入(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';

 

更新视图的限制:

一些视图是不可更新的,因为对这些视图的更新不能唯一地有意义地转换成对相应基本表的更新 

例:视图S_G为不可更新视图。 

UPDATE  S_G
SET          Gavg=90
WHERE  Sno= '201215121';

这个对视图的更新无法转换成对基本表SC的更新

 

一般地,行列子集视图是可更新的。除行列子集视图外,有些视图理论上是可更新的,
但它们的确切特征还是尚待研究的课题。还有些视图从理论上就是不可更新的。

 目前,各个关系数据库管理系统般都只允许对行列子集视图进行更新 而且各个系统对视图的更新还有更进一步的规定。由于各系统实现方法上的差异,这些规定也不尽相同。

例如DB2的规定:

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

 

以上是关于MySQL——视图的介绍的主要内容,如果未能解决你的问题,请参考以下文章

从mysql的片段中加载ListView

回收站视图未显示在片段中

如何从片段内的列表视图打开链接网址?

如何使列表视图出现在片段中?

如何从活动中更改片段中视图的可见性

片段中的网格视图