欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > PPT文档下载  

    关系数据库标准语言SQL补充.ppt

    • 资源ID:5039654       资源大小:220.49KB        全文页数:41页
    • 资源格式: PPT        下载积分:15金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要15金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    关系数据库标准语言SQL补充.ppt

    视图:从一个或几个基本表(或视图)导出的表。建立视图的优点 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 建立信息系学生的视图,并要求进行修改和插入操作时仍须保证该视图只有信息系的学生,CREATE VIEW IS_Student AS SELECT Sno,Sname,Sage FROM Student WHERE Sdept=IS WITH CHECK OPTION;,由于在定义IS_Student视图时加上了WITH CHECK OPTION子句,以后对该视图进行插入、修改和删除操作时,DBMS会自动加上Sdept=IS的条件。,视图不仅可以建立在单个基本表上,也可以建立在多个基本表上。,例3建立信息系选修了1号课程的学生的视图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;,视图不仅可以建立在一个或多个基本表上也可以建立在一个或多个已定义好的视图上,或同时建立在基本表与视图上。,例4建立信息系选修了1号课程且成绩在90分以上的学生的视图CREATE VIEW IS_S2 AS SELECT Sno,Sname,Grade FROM IS_S1 WHERE Grade=90;,定义基本表时,为了减少数据库中的冗余数据,表中只存放基本数据,由基本数据经过各种计算派生出的数据一般是不存储的。但由于视图中的数据并不实际存储,所以定义视图时可以根据应用的需要,设置一些派生属性列。这些派生属性由于在基本表中并不实际存在,所以有时也称他们为虚拟列。带虚拟列的视图我们称为带表达式的视图。,例5定义一个反映学生出生年份的视图CREATE VIEW BT_S(Sno,Sname,Sbirth)AS SELECT Sno,Sname,1996-Sage FROM Student;,由于BT_S视图中的出生年份值是通过一个表达式计算得到的,不是单纯的属性名,所以定义视图时必须明确定义该视图的各个属性列名。BT_S视图是一个带表达式的视图。,还可以用带有集函数和GROUP BY子句的查询来定义视图。这种视图称为分组视图。,例6将学生的学号及他的平均成绩定义为一个视图CREAT VIEW S_G(Sno,Gavg)AS SELECT Sno,AVG(Grade)FROM SC GROUP BY Sno;,例7将Student表中所有女生记录定义为一个视图CREATE VIEW F_Student(stdnum,name,sex,age,dept)AS SELECT*FROM Student WHERE Ssex=女;,这里视图F_Student是由子查询“SELECT*建立的。由于该视图一旦建立后,Student表就构成了视图定义的一部分,如果以后修改了基本表Student的结构,则Student表与F_Student视图的映像关系受到破坏,因而该视图就不能正确工作了。为避免出现这类问题,可以采用下列两种方法:,建立视图时明确指明属性列名,而不是简单地用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_S1DROP VIEW IS_S1;执行此语句后,IS_S1视图的定义将从数据字典中删除。由IS_S1视图导出的IS_S2视图的定义虽仍在数据字典中,但该视图已无法使用了,因此应该同时删除。,3.5.2查询视图,DBMS执行对视图的查询时,首先进行有效性检查,检查查询涉及的表、视图等是否在数据库中存在,如果存在,则从数据字典中取出查询涉及的视图的定义,把定义中的子查询和用户对视图的查询结合起来,转换成对基本表的查询,然后再执行这个经过修正的查询。将对视图的查询转换为对基本表的查询的过程称为视图的消解(View Resolution)。,例1在信息系学生的视图中找出年龄小于20岁的学生SELECT Sno,SageFROM 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 AND Sage20;,视图是定义在基本上的虚表,它可以和其他基本表一起使用,实现连接查询或嵌套查询。这也就是说,在关系数据库的三级模式结构中,外模式不仅包括视图,而且还可以包括一些基本表。,例2查询信息系选修了1号课程的学生SELECT Sno,Sname FROM IS_Student,SCWHERE IS_Student.Sno=SC.Sno AND SC.Cno=1;本查询涉及虚表IS_Student和基本表SC,通过这两个表的连接来完成用户请求。,3.5.3更新视图,更新视图包括插入(INSERT)、删除(DELETE)和修改(UPDATE)三类操作。由于视图是不实际存储数据的虚表,因此对视图的更新,最终要转换为对基本表的更新。为防止用户通过视图对数据进行增删改时,无意或故意操作不属于视图范围内的基本表数据,可在定义视图时加上WITH CHECK OPTION子句,这样在视图上增删改数据时,DBMS会进一步检查视图定义中的条件,若不满足条件,则拒绝执行该操作。,例1将信息系学生视图IS_Student中学号为95002的学生姓名改为“刘辰”UPDATE IS_StudentSET Sname=刘辰WHERE Sno=95002;与查询视图类似,DBMS执行此语句时,首先进行有效性检查,检查所涉及的表、视图等是否在数据库中存在,如果存在,则从数据字典中取出该语句涉及的视图的定义,把定义中的子查询和用户对视图的更新操作结合起来,转换成对基本表的更新,然后再执行这个经过修正的更新操作。转换后的更新语句为:,UPDATE Student SET Sname=刘辰 WHERE Sno=95002 AND Sdept=IS;,例2向信息系学生视图IS_S中插入一个新的学生记录,其中学号为95029,姓名为赵新,年龄为20岁INSERTINTO IS_StudentVALUES(95029,赵新,20);DBMS将其转换为对基本表的更新:INSERT INTO Student(Sno,Sname,Sage,Sdept)VALUES(95029,赵新,20,IS);这里系统自动将系名IS放入VALUES子句中。,例3删除计算机系学生视图CS_S中学号为95029的记录DELETEFROM IS_StudentWHERE Sno=95029;DBMS将其转换为对基本表的更新:DELETE FROM Student WHERE Sno=95029 AND Sdept=IS;,更新的限制,在关系数据库中,并不是所有的视图都是可更新的,因为有些视图的更新不能唯一地有意义地转换成对相应基本表的更新。,DB2规定:,1.若视图是由两个以上基本表导出的,则此视图不允许更新。2.若视图的字段来自字段表达式或常数,则不允许对此视图执行INSERT和UPDATE操作,但允许执行DELETE操作。3.若视图的字段来自集函数,则此视图不允许更新。4.若视图定义中含有GROUP BY子句,则此视图不允许更新。5.若视图定义中含有DISTINCT短语,则此视图不允许更新。,6.若视图定义中有嵌套查询,并且内层查询的FROM子句中涉及的表也是导出该视图的基本表,则此视图不允许更新。例如将成绩在平均成绩之上的元组定义成一个视图GOOD_SC:CREATE VIEW GOOD_SC AS SELECT Sno,Cno,Grade FROM SC WHERE Grade(SELECT AVG(Grade)FROM SC);导出视图GOOD_SC的基本表是SC,内层查询中涉及的表也是SC,所以视图GOOD_SC是不允许更新的。7.一个不允许更新的视图上定义的视图也不允许更新。,视图的优点,视图能够简化用户的操作视图使用户能以多种角度看待同一数据视图对重构数据库提供了一定程度的逻辑独立性视图能够对机密数据提供安全保护,数据控制,一、授权GRANT,ON TO,WITH GRANT OPTION;二、收回权限REVOKE,ON FROM,例1把查询Student表权限授给用户U1 GRANT SELECT ON TABLE Student TO U1;例2把对Student表和Course表的全部权限授予用户U2和U3 GRANT ALL PRIVILIGES ON TABLE Student,Course TO U2,U3;例3把对表SC的查询权限授予所有用户 GRANT SELECT ON TABLE SC TO PUBLIC;,例4把查询Student表和修改学生学号的权限授给用户U4这里实际上要授予U4用户的是对基本表Student的SELECT权限和对属性列Sno的UPDATE权限。授予关于属性列的权限时必须明确指出相应属性列名。完成本授权操作的SQL语句为:GRANT UPDATE(Sno),SELECT ON TABLE Student TO U4;,例5把对表SC的INSERT权限授予U5用户,并允许他再将此权限授予其他用户GRANT INSERT ON TABLE SC TO U5 WITH GRANT OPTION;执行此SQL语句后,U5不仅拥有了对表SC的INSERT权限,还可以传播此权限,即由U5用户发上述GRANT命令给其他用户。例如U5可以将此权限授予U6:GRANT INSERT ON TABLE SC TO U6 WITH GRANT OPTION;同样,U6还可以将此权限授予U7:GRANT INSERT ON TABLE SC TO U7;因为U6未给U7传播的权限,因此U7不能再传播此权限,例6DBA把在数据库S_C中建立表的权限授予用户U8GRANT CREATETAB ON DATABASE S_C TO U8;由上面的例子可以看到,GRANT语句可以一次向一个用户授权,如例1所示,这是最简单的一种授权操作;也可以一次向多个用户授权,如例2、例3等所示;还可以一次传播多个同类对象的权限,如例2所示;甚至一次可以完成对基本表、视图和属性列这些不同对象的授权,如例4所示;但授予关于DATABASE的权限必须与授予关于TABLE的权限分开,因为它们使用不同的对象类型关键字。,例7把用户U4修改学生学号的权限收回REVOKE UPDATE(Sno)ON TABLE Student FROM U4;例8收回所有用户对表SC的查询权限REVOKE SELECT ON TABLE SC FROM PUBLIC;例9把用户U5对SC表的INSERT权限收回REVOKE INSERT ON TABLE SC FROM U5;,在例5中,U5又将对SC表的INSERT权限授予了U6,而U6又将其授予了U7,执行此REVOKE语句后,DBMS在收回U5对SC表的INSERT权限的同时,还会自动收回U6和U7对SC表的INSERT权限,即收回权限的操作会级联下去的。但如果U6或U7还从其他用户处获得对SC表的INSERT权限,则他们仍具有此权限,系统只收回直接或间接从U5处获得的权限。,可见,SQL提供了非常灵活的授权机制。用户对自己建立的基本表和视图拥有全部的操作权限,并且可以用GRANT语句把其中某些权限授予其他用户。被授权的用户如果有“继续授权”的许可,还可以把获得的权限再授予其他用户。DBA拥有对数据库中所有对象的所有权限,并可以根据应用的需要将不同的权限授予不同的用户。而所有授予出去的权力在必要时又都可以用REVOKE语句收回。,嵌入式SQL,一般形式:EXEC SQL;,利用如下关系模式完成要求的操作。S(SNO,SNAME,AGE,SEX,SDEPT)C(CNO,CNAME,CREDIT,TEACHER,PRE_CNO)S_C(SNO,CNO,GRADE),1 查询与“王英”在同一个系学习的学生学号和姓名,请使用自连接查询实现2 查询年龄大于23岁的男同学的学号和姓名;3 查询0004号学生选修课程的课程号、课程名和任课教师的姓名;4 查询“张小飞”同学没有选修的课程的课程号和课程名;5 找出最大年龄学生的姓名和年龄6 查询至少选修了3门课程的学生的学号和姓名;7 查询全部学生都选修了的课程号和课程名;8 在学习表中删除没有成绩的选课纪录;9 把“高等数学”的所有不及格成绩都改为60分;10 新建一个未选课的学生信息表Stu_Nosel,利用子查询的结果将所有记录批量插入到Stu_Nosel中。,

    注意事项

    本文(关系数据库标准语言SQL补充.ppt)为本站会员(小飞机)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开