数据库系统-视图


视图

视图是从一个或几个基本表(或视图)导出的表

它与基本表不同,是一个虚表.

数据库中只*存放视图的定义,而不存放视图对应的数据,这些数据仍存放在原来的基本表中。所以一旦基本表中的数据发生变化,从视图中查询出的数据也就随之改变了

视图就像一个窗口,透过它可以看到数据库中自己感兴趣的数据及其变化

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

如果已有视图建立在基本表上,这时修改基本表属性,可能导致视图不能运作;可以先删除视图,建立新视图

定义视图

1
2
3
CREATE VIEW <视图名>[ (<列名> [,<列名>] …)]
AS <子查询>
WITH CHECK OPTION];

子查询可以是任意的SELECT语句,是否可以含有ORDER B Y 子句和 DISTINCT
短语,则取决于具体系统的实现(通常不能用ODER BY 和 DISTINCT)

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

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

但在下列三种情况下必须明确指定组成视图的所有列名
(1) 某个目标列不是单纯的属性名,而是聚集函数或列表达式
(2 ) 多表连接时选出了几个同名列作为视图的字段
(3 ) 需要在视图中为某个列启用新的更合适的名字

image-20230627175123111

建立在一个基本表

image-20230627175206807

1
2
3
4
5
CREATE VIEW IS_Student
AS
SELECT Sno,Sname,Sage
FROM Student
WHERE Sdept='IS';
1
2
3
4
5
6
7
8
CREATE VIEW IS_Student
AS
SELECT Sno,Sname,Sage
FROM Student
WHERE Sdept='IS'
WITH CHECK OPTION;
/*由于在定义IS_Student视图时加上了 WITH CHECK OPT1ON子句,以后对该视图进
行插入、修改和删除操作时,关系数据库管理系统会自动加上Sdept='IS'的条件。*/

关系数据库管理系统执行CREATE VIEW 语句的结果只是把视图的定义存入数据字
并不执行其中的SELECT语句。只是在对视图查询时,才按视图的定义从基本表中将数据査出

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

image-20230627175321960

建立在多个基本表

1
2
3
4
5
6
7
CREATE VIEW IS_Sl(Sno,Sname,Grade)
AS
SELECT Student.Sno,Sname,Grade
FROM Student,SC
WHERE Sdept='IS' AND
Student.Sno=SC.Sno AND
SC.Cno='1';

由于视图IS_S1的属性列中包含了 Student表 与 SC 表的同名列Sno ,所以必须在视图名后面明确说明视图的各个属性列名。

image-20230627175608559

代表达式的试图

1
由基本数据经过各种计算派生出的数据一般是不存储的。这些派生属性由于在基本表中并不实际存在,也称它们为虚拟列。带虚拟列的视图也称为**带表达式的视图

image-20230627175732877

分组视图

image-20230627175859612

建立在一个视图上

1
2
3
4
5
CREATE VIEW IS_S2
AS
SELECT Sno,Sname,Grade
FROM IS_S1
WHERE Grade>=90;

image-20230627180026893

建立在多个视图上

分组视图

GROUP BY 子句的查询来定义视图,这种视图称为分组视图

1
2
3
4
5
6
CREATE VIEW S_G(Sno,Gavg)
AS
SELECT Sno,AVG(Grade)
FROM SC
GROUP BY Sno;
/*由于AS子句中SELECT语句的目标列平均成绩是通过作用聚集函数得到的,所CREATE VIEW 中必须明确定义组成S_G 视图的各个属性列名。 S_G 是一个分组视图*/

删除视图

1
DROP VIEW <视图名> [CASCADE] ;

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

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

查询视图

与查询基本表差不多

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

1
2
3
4
5
6
7
SELECT Sno,Sage
FROM IS_Student
WHERE Sage<20;
/*本例转换后的查询语句为*/
SELECT Sno,Sage
FROM Student
WHERE Sdept='lS' AND Sage<20;

而有时候可能出现转换错误

1
2
3
4
5
6
7
8
SELECT *
FROM S_G
WHERE Gavg>=90;
/*将本例中的查询语句与定义S_G 视图的子查询结合,形成下列查询语句:*/
SELECT Sno,AVG(Grade)
FROM SC
WHERE AVG(Grade)>=90
GROUP BY Sno;

WHERE子句中是不能用聚集函数作为条件表达式的,因此执行此修正后的查询
将会出现语法错误

目前多数关系数据库系统对行列子集视图的查询均能进行正确转换。但对非行列
子 集 视 图 的 查 询 就 不 一 定 能 做 转 换 了 ,因此这类查询应该直接对基本表进行 。

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

更新视图

image-20230627180812562

UPDATE

1
2
3
4
5
6
7
UPDATE IS_Student
SET Sname='刘辰'
WHERE Sno='201215122';
转换后的更新语句为
UPDATE Student
SET Sname='刘辰'
WHERE Sno='201215122' AND Sdept='IS';

INSERT

1
2
3
4
5
6
7
INSERT
INTO IS_Student
VALUES('201215129', '丁赵新',20);
转换为对基本表的更新:
INSERT
INTO Student(Sno,Sname,Sage,Sdept)
VALUES('2O1215129','赵新',20,'IS');

DELETE

1
2
3
4
5
6
7
DELETE
FROM IS_Student
WHERE Sno='201215129'
转换为对基本表的更新:
DELETE
FROM Student
WHERE Sno='201215129' AND Sdept='IS';

在关系数据库中,并不是所有的视图都是可更新的,因为有些视图的更新不能唯一地有意义地转换成对相应基本表的更新

1
2
3
4
5
6
7
8
9
CREATE VIEW S_G(Sno,Gavg)
AS
SELECT Sno,AVG(Grade)
FROM SC
GROUP BY Sno;
/*如果想把视图S_G 中学号为“ 201215121 ” 的学生的平均成绩改成9 0 分 , SQL语句如下:*/
UPDATE S_G
SET Gavg=90
WHERE Sno='20121512'

但这个对视图的更新是无法转换成对基本表S C 的更新的,因为系统无法修改各科成绩,以使平均成绩成为90。所 以 S_G 视图是不可更新的。

一般地,行列子集视图是可更新的

受限更新

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

视图作用

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

视图查看

1
sp_helptext 视图名

视图加密

1
2
3
4
5
6
7
CREATE VIEW 视图名
AS
.......
WITH ENCRYPTION -- 加密


sp_helptext 视图名 报错

即使慢,驰而不息,纵会落后,纵会失败,但一定可以达到他所向的目标。

本文标题:数据库系统-视图

文章作者:TTYONG

发布时间:2020年05月12日 - 14:05

最后更新:2023年06月27日 - 18:06

原始链接:http://tianyong.fun/%E6%95%B0%E6%8D%AE%E5%BA%93%E7%B3%BB%E7%BB%9F-%E8%A7%86%E5%9B%BE-5.html

许可协议: 转载请保留原文链接及作者。

多少都是爱
0%