关系数据库标准语言续PPT讲稿.ppt
《关系数据库标准语言续PPT讲稿.ppt》由会员分享,可在线阅读,更多相关《关系数据库标准语言续PPT讲稿.ppt(40页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、关系数据库标准语言续第1页,共40页,编辑于2022年,星期五2视图:视图:从一个或几个基本表(或视图)导出的表。一、建立视图的优点一、建立视图的优点1、简化用户的操作2、灵活3、提供一定程度的逻辑独立性4、提供安全保护第2页,共40页,编辑于2022年,星期五3二、定义视图二、定义视图1、建立视图 CREATE VIEW (,)AS WITH CHECK OPTION;2、删除视图 DROP VIEW 三、查询视图(同表查询一样)四、更新视图(同表更新一样)第3页,共40页,编辑于2022年,星期五4如果CREATE VIEW语句仅指定了视图名,省略了组成视图的各个属性列名,则隐含该视图由子
2、查询中SELECT子句目标列中的诸字段组成。在下列三种情况三种情况下必须明确指定组成视图的所有列名:其中某个目标列不是单纯的属性名,而是集函数或列表达式 多表连接时选出了几个同名列作为视图的字段 需要在视图中为某个列启用新的更合适的名称第4页,共40页,编辑于2022年,星期五5例例1 1 建立信息系学生的视图。建立信息系学生的视图。CREATEVIEWIS_StudentASSELECTSno,Sname,ageFROMSWHEREdept=IS;行列子集视图行列子集视图:视图是从单个基本表导出的,并且只是去掉了基本表的某些行和某些列,但保留了码。第5页,共40页,编辑于2022年,星期五6
3、例例2 2 建立信息系学生的视图,并要求进行修改和插入操建立信息系学生的视图,并要求进行修改和插入操作时仍须保证该视图只有信息系的学生作时仍须保证该视图只有信息系的学生CREATEVIEWIS_StudentASSELECTSno,Sname,ageFROMSWHEREdept=ISWITHCHECKOPTION;第6页,共40页,编辑于2022年,星期五7视图不仅可以建立在单个基本表上,也可以建立在多个基本表上。例例3 3建立信息系选修了建立信息系选修了1 1号课程的学生的视图号课程的学生的视图CREATEVIEWIS_S1(Sno,Sname,Grade)ASSELECTS.Sno,Sna
4、me,GradeFROMS,SCWHEREdept=IS ANDS.Sno=SC.SnoANDSC.Cno=1;第7页,共40页,编辑于2022年,星期五8 视图不仅可以建立在一个或多个基本表上也可以建立在一个或多个已定义好的视图上,或同时建立在基本表与视图上。例例4 4建立信息系选修了建立信息系选修了1 1号课程且成绩在号课程且成绩在9090分以上分以上的学生的视图的学生的视图CREATEVIEWIS_S2ASSELECTSno,Sname,GradeFROMIS_S1WHEREGrade=90;第8页,共40页,编辑于2022年,星期五9定义基本表时,为了减少数据库中的冗余数据,表中只存放
5、基本数据,由基本数据经过各种计算派生出的数据一般是不存储的。但由于视图中的数据并不实际存储,所以定但由于视图中的数据并不实际存储,所以定义视图时可以根据应用的需要,设置一些派义视图时可以根据应用的需要,设置一些派生属性列。生属性列。这些派生属性由于在基本表中并不实际存在,所以有时也称他们为虚拟列虚拟列。带虚拟列的视图我们称为带表达式的视图表达式的视图。第9页,共40页,编辑于2022年,星期五10例例5 5定义一个反映学生出生年份的视图定义一个反映学生出生年份的视图CREATEVIEWBT_S(Sno,Sname,Sbirth)ASSELECTSno,Sname,2010-ageFROMS;带
6、表达式的视图第10页,共40页,编辑于2022年,星期五11还可以用带有集函数和GROUP BY子句的查询来定义视图。这种视图称为分组视图分组视图。例例6 6 将学生的学号及他的平均成绩定义为一个将学生的学号及他的平均成绩定义为一个视图视图CREATVIEWS_G(Sno,Gavg)ASSELECTSno,AVG(Grade)FROMSCGROUPBYSno;第11页,共40页,编辑于2022年,星期五12例例7 7将将S S表中所有女生记录定义为一个视图表中所有女生记录定义为一个视图CREATEVIEWF_Student(stdnum,name,sex,age,dept)ASSELECT*F
7、ROMSWHEREsex=女;这里视图F_Student是由子查询“SELECT*建立的。由于该视图一旦建立后,S表就构成了视图定义的一部分,如果以后修改了基本表S的结构,则S表与F_Student视图的映像关系受到破坏,因而该视图就不能正确工作了。为避免出现这类问题,可以采用下列两种方法:第12页,共40页,编辑于2022年,星期五131.建立视图时明确指明属性列名,而不是简单地用SELECT*。即:CREATEVIEWF_Student(stdnum,name,sex,age,dept)ASSELECTSno,Sname,sex,age,deptFROMSWHERESsex=女;2.在修改
8、基本表之后删除原来的视图,然后重建视图。这是最保险的方法。第13页,共40页,编辑于2022年,星期五142、删除视图语句的格式为:DROP VIEW;一个视图被删除后,由此视图导出的其他视图也将失效,用户应该使用DROP VIEW语句将他们一一删除。第14页,共40页,编辑于2022年,星期五15例例8 8删除视图删除视图IS_S1IS_S1DROPVIEWIS_S1;执行此语句后,IS_S1视图的定义将从数据字典中删除。由IS_S1视图导出的IS_S2视图的定义虽仍在数据字典中,但该视图已无法使用了,因此应该同时删除。第15页,共40页,编辑于2022年,星期五16三、查询视图DBMSDB
9、MS执行对视图的查询时,首先进行有效执行对视图的查询时,首先进行有效性检查,检查查询涉及的表、视图等是否在性检查,检查查询涉及的表、视图等是否在数据库中存在,如果存在,则从数据字典中数据库中存在,如果存在,则从数据字典中取出查询涉及的视图的定义,把定义中的子取出查询涉及的视图的定义,把定义中的子查询和用户对视图的查询结合起来,转换成查询和用户对视图的查询结合起来,转换成对基本表的查询,然后再执行这个经过修正对基本表的查询,然后再执行这个经过修正的查询。的查询。将对视图的查询转换为对基本表的查询的过程称为视图的消解视图的消解(View Resolution)。第16页,共40页,编辑于2022年
10、,星期五17例1在信息系学生的视图中找出年龄小于20岁的学生SELECTSno,ageFROMIS_StudentWHEREage20;DBMS执行此查询时,将其与IS_Student视图定义中的子查询 SELECTSno,Sname,ageFROMSWHEREdept=IS;结合起来,转换成对基本表S的查询,修正后的查询语句为第17页,共40页,编辑于2022年,星期五18SELECTSno,SageFROMStudentWHERESdept=ISANDSage=90S_G的定义为Selectsno,avg(grade)froms_cgroupbysno该转换后得到:第21页,共40页,编辑
11、于2022年,星期五22该查询转换后得到SELECTSNO,AVG(GRADE)FROMS_CWHEREAVG(GRADE)=90这是错误的!这是错误的!正确的查询应该是SELECTSNO,AVG(GRADE)FROMS_CGROUPBYSNOHAVINGAVG(GRADE)=90此类查询应该直接对表进行!第22页,共40页,编辑于2022年,星期五23四、更新视图更新视图包括插入(INSERT)、删除(DELETE)和修改(UPDATE)三类操作。由于视图是不实际存储数据的虚表,因此对视图的更新,最终要转换为对基本表的更新。为防止用户通过视图对数据进行增删改时,无意或故意操作不属于视图范围内
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 关系 数据库 标准 语言 PPT 讲稿
限制150内