032关系数据库标准语言S询问QL补充.pptVIP

  • 5
  • 0
  • 约7.09千字
  • 约 41页
  • 2018-12-22 发布于福建
  • 举报
032关系数据库标准语言S询问QL补充

视图:从一个或几个基本表(或视图)导出的表。 建立视图的优点 1、简化用户的操作 2、灵活 3、提供一定程度的逻辑独立性 4、提供安全保护 3.5.1定义视图 1、建立视图 CREATE VIEW 视图名[(列名[,列名]…)] AS 子查询 [WITH CHECK OPTION]; 如果CREATE VIEW语句仅指定了视图名,省略了组成视图的各个属性列名,则隐含该视图由子查询中SELECT子句目标列中的诸字段组成。但在下列三种情况下必须明确指定组成视图的所有列名: 其中某个目标列不是单纯的属性名,而是集函数或列表达式    多表连接时选出了几个同名列作为视图的字段 需要在视图中为某个列启用新的更合适的名 需要说明的是,组成视图的属性列名必须依照上面的原则,或者全部省略或者全部指定,没有第三种选择。 例1 建立信息系学生的视图。 CREATE VIEW IS_Student ?????? AS ?????? SELECT Sno, Sname, Sage ????? ?FROM Student ?????? WHERE Sdept=IS; 实际上,DBMS执行CREATE VIEW语句的结果只是把对视图的定义存入数据字典,并不执行其中的SELECT语句。只是在对视图查询时,才按视图的定义从基本表中将数据查出。 例2 建立信息系学生的视图,并要求进行修改和插入操作时仍须保证该视图只有信息系的学生 视图不仅可以建立在单个基本表上,也可以建立在多个基本表上。 视图不仅可以建立在一个或多个基本表上也可以建立在一个或多个已定义好的视图上,或同时建立在基本表与视图上。 定义基本表时,为了减少数据库中的冗余数据,表中只存放基本数据,由基本数据经过各种计算派生出的数据一般是不存储的。但由于视图中的数据并不实际存储,所以定义视图时可以根据应用的需要,设置一些派生属性列。这些派生属性由于在基本表中并不实际存在,所以有时也称他们为虚拟列。带虚拟列的视图我们称为带表达式的视图。 例5定义一个反映学生出生年份的视图 CREATE VIEW BT_S(Sno, Sname, Sbirth) ?????? AS SELECT Sno, Sname, 1996-Sage ?????? FROM Student; 还可以用带有集函数和GROUP BY子句的查询来定义视图。这种视图称为分组视图。 例7将Student表中所有女生记录定义为一个视图 CREATE VIEW F_Student(stdnum,name,sex,age,dept) ?????? AS SELECT * ?????? FROM Student ?????? WHERE Ssex=‘女’; 建立视图时明确指明属性列名,而不是简单地用SELECT *。即: CREATE VIEW F_Student(stdnum,name,sex,age,dept) ??????AS SELECT Sno, Sname, Ssex, Sage, Sdept ??????FROM Student ??????WHERE Ssex=‘女’; 在修改基本表之后删除原来的视图,然后重建视图。这是最保险的方法。 2、删除视图 语句的格式为: DROP VIEW 视图名; 一个视图被删除后,由此视图导出的其他视图也将失效,用户应该使用DROP VIEW语句将他们一一删除。 例8删除视图IS_S1 DROP VIEW IS_S1; 执行此语句后,IS_S1视图的定义将从数据字典中删除。由IS_S1视图导出的IS_S2视图的定义虽仍在数据字典中,但该视图已无法使用了,因此应该同时删除。 3.5.2查询视图 DBMS执行对视图的查询时,首先进行有效性检查,检查查询涉及的表、视图等是否在数据库中存在,如果存在,则从数据字典中取出查询涉及的视图的定义,把定义中的子查询和用户对视图的查询结合起来,转换成对基本表的查询,然后再执行这个经过修正的查询。将对视图的查询转换为对基本表的查询的过程称为视图的消解(View Resolution)。 例1在信息系学生的视图中找出年龄小于20岁的学生 SELECT Sno, Sage FROM IS_Student WHERE Sage20; DBMS执行此查询时,将其与IS_Student视图定义中的子查询 SELECT Sno, Sname, Sage     FROM Student WHERE Sdept=IS ; 结合起来,转换成对基本表Student的查询,修正后的查询语句为 SELECT Sno, Sage FROM Student WHERE Sdept=IS

文档评论(0)

1亿VIP精品文档

相关文档