ImageVerifierCode 换一换
格式:DOCX , 页数:74 ,大小:73.15KB ,
资源ID:17545715      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/17545715.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(SQL习题Word文件下载.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

SQL习题Word文件下载.docx

1、基本表:在SQL中,把传统的关系模型中的关系模式称为基本表(Base Table). 基本表是实际存储在数据库中的表,对应一个关系. 视图:在SQL中,把传统的关系模型中的子模式称为视图(View),视图是从若干基本表和(或)其他视图构造出来的表. 相关子查询:在嵌套查询中出现的符合以下特征的子查询:子查询中查询条件依赖于外层查询中的某个值, 所以子查询的处理不只一次,要反复求值,以供外层查询使用. 联接查询:查询时先对表进行笛卡尔积操作,然后再做等值联接,选择,投影等操作. 联接查询的效率比嵌套查询低. 嵌入式SQL:嵌入在高级语言的程序中使用的SQL语言称为嵌入式SQL. 游标:游标是与某

2、一查询结果相联系的符号名,用于把集合操作转换成单记录处理方式.2,对于教学数据库的三个基本表 学生 S(S#,SNAME,AGE,SEX) 学习 SC(S#,C#,GRADE) 课程 C(C#,CNAME,TEACHER) 试用SQL的查询语句表达下列查询: (1)检索LIU老师所授课程的课程号和课程名. SELECT C#,CNAME FROM C WHERE TEACHER=LIU(2)检索年龄大于23岁的男学生的学号和姓名. SELECT S#,SNAME FROM S WHERE (AGE23) AND (SEX=M) (3)检索至少选修LIU老师所授课程中一门课程的女学生姓名. SE

3、LECT SNAME WHERE SEX=F AND S# IN (SELECT S# FROM SC WHERE C# IN (SELECT C# FROM C WHERE TEACHER=NOTICE:有多种写法,比如联接查询写法: SELECT SNAME FROM S,SC,C WHERE SEX=AND SC.S#=S.S# AND SC.C#=C.C# AND TEACHER=但上一种写法更好一些. (4)检索WANG同学不学的课程的课程号. SELECT C# WHERE C# NOT IN WHERE S# IN FROM S WHERE SNAME=WANG) (5)检索至少

4、选修两门课程的学生学号. SELECT DISTINCT(自连接) X.s# GROUP BY X.s#HAVING count(x.s#)=2;Notice:对表SC进行自连接,X,Y是SC的两个别名. (6)检索全部学生都选修的课程的课程号与课程名. WHERE NOT EXISTS (SELECT * WHERE S# NOT IN WHERE SC.C#=C.C#) 要从语义上分解:(1)选择课程的课程号与课程名,不存在不选这门课的同学. 其中,不选这门课的同学可以表示为:SELECT * WHERE S# NOT IN (SELECT * FROM SC WHERE SC.C#=C.

5、C#) 或者WHERE S.S#=C.S# AND SC.C#=C.C# ) (7)检索选修课程包含LIU老师所授课的学生学号. SELECT DISTINCT S# WHERE C# IN 3, 设有两个基本表R(A,B,C)和S(A,B,C)试用SQL查询语句表达下列关系代数表达式:(1)RS (2)RS (3)R-S (4)A,B(R)B,C(S) 3,(1)SELECT A,B,C FROM R UNION SELECT A,B,C (2)SELECT A,B,C INTERSECT 4, 试用SQL查询语句表达下列对教学数据库中三个基本表S,SC,C的查询:(1)统计有学生选修的课程

6、门数.SELECT COUNT(DISTINCT C#) (2)求选修C4课程的学生的平均年龄.SELECT AVG(AGE)FROM SWHERE S# IN (SELECT S# WHERE C#=C4); (3)求LIU老师所授课程的每门课程的学生平均成绩.SELECT AVG(GRADE)FROM SCWHERE C#=(SELECT C#FROM CWHERE C.TEACHER=LIU)GROUP BY C#;或SELECT CNAME,AVG(GRADE) FROM SC ,C WHERE SC.C#=C.C# AND TEACHER=GROUP BY C#(4)统计每门课程的学

7、生选修人数(超过10人的课程才统计).要求输出课程号和选修人数, 查 询结果按人数降序排列,若人数相同,按课程号升序排列.SELECT DISTINCT C#,COUNT(S#) GROUP BY C# HAVING COUNT(S#)10 ORDER BY 2 DESC, C# ASC(5)检索学号比WANG同学大,而年龄比他小的学生姓名.SELECT SnameWHERE S#(SELECT S#WHERE S.Sname=WANG)AND AGE(SELECT AVG(AGE) FROM S WHERE SEX=)AND SEX=M ;5, 试用SQL更新语句表达对教学数据库中三个基本表

8、S,SC,C的各个更新操作:(1)往基本表S中插入一个学生元组(S9,WU,18).(2)在基本表S中检索每一门课程成绩都大于等于80分的学生学号,姓名和性别, 并把检索到的值送往另一个已存在的基本表STUDENT(S#,SANME,SEX).(3)在基本表SC中删除尚无成绩的选课元组.(4)把WANG同学的学习选课和成绩全部删去(5)把选修MATHS课不及格的成绩全改为空值.(6)把低于总平均成绩的女同学成绩提高5%. (7)在基本表SC中修改C4课程的成绩,若成绩小于等于75分时提高5%, 若成绩大于75分时提高4%(用两个UPDATE语句实现). 6, 在宿主语言的程序中使用SQL语句有

9、哪些规定 7,嵌入式SQL语句何时不必涉及到游标 何时必须涉及到游标 答案:一,1,B 2,C 3,D 4,C 5,B 6,D二,1,嵌入式 交互式 2,选择3,基本表导出的表 4,数据查询 数据更新 数据插入 数据删除5,视图或部分基本表 基本表 存储文件 6,GROUP BY三,1,名词解释 游标是与某一查询结果相联系的符号名,用于把集合操作转换成单记录处理方式. 2,(1)检索LIU老师所授课程的课程号和课程名. (SELECT S# (SELECT C# FROM S,SC,C AND SC.S#=S.S# AND SC.C#=C.C# AND TEACHER=WHERE S# IN

10、WHERE SNAME=SELECT DISTINCT X.SNO FROM SC X,SC Y WHERE X.SNO=Y.SNO AND X.CNOY.CNO WHERE SC.C#=C.C#) WHER,S.C FROM R,S WHERE R.B=S.B4, (1)统计有学生选修的课程门数. SELECT COUNT(DISTINCT C#) FROM SC (2)求选修C4课程的学生的平均年龄. SELECT AVG(AGE) 或者, FROM S,SC WHERE S.S#=SC.S# AND C#=004(3)求LIU老师所授课程的每门课程的学生平均成绩. (4)统计每门课程的学

11、生选修人数(超过10人的课程才统计).要求输出课程号和选修人数, 查询结果按人数降序排列,若人数相同,按课程号升序排列. ORDER BY 2 DESC, C# ASC (5)检索学号比WANG同学大,而年龄比他小的学生姓名. SELECT X.SNAME FROM S AS X, S AS Y WHERE Y.SNAME= AND X.S#Y.S# AND X.AGE(SELECT AVG(AGE) FROM S AS Y WHERE Y.SEX=女5, (1)往基本表S中插入一个学生元组(,18). INSERT INTO S(S#,SNAME,AGE) VALUES(59,18) (2)

12、在基本表S中检索每一门课程成绩都大于等于80分的学生学号,姓名和性别, 并把检索到的值送往另一个已存在的基本表STUDENT(S#,SANME,SEX). INSERT INTO STUDENT(S#,SNAME,SEX) SELECT S#,SNAME,SEX FROM S WHERE NOT EXISTS (SELECT * FROM SC WHERE GRADE80 AND S.S#=SC.S#) (3)在基本表SC中删除尚无成绩的选课元组. DELETE FROM SC WHERE GRADE IS NULL (4)把WANG同学的学习选课和成绩全部删去. (5)把选修MATHS课不及

13、格的成绩全改为空值. UPDATE SC SET GRADE=NULL WHERE GRADE60 AND C# IN WHERE CNAME=MATHS6)把低于总平均成绩的女同学成绩提高5%. SET GRADE=GRADE*1.05 (SELECT AVG(GRADE) FROM SC) AND S# IN (SELECT S# FROM S WHERE SEX= AND GRADE75 6, 在宿主语言的程序中使用SLQ语句有以下规定:(1)在程序中要区分SQL语句与宿主语言语句 (2)允许嵌入的SQL语句引用宿主语言的程序变量(称为共享变量),但有两条规定:1)引用时,这些变量前必须

14、加:作为前缀标识,以示与数据库中变量有区别. 2)这些变量由宿主语言的程序定义,并用SQL的DECLARE语句说明. (3)SQL的集合处理方式与宿主语言单记录处理方式之间要协调. 需要采用游标机制,把集合操作转换成单记录处理方式. 7, (1)INSERT,DELETE,UPDATE语句,查询结果肯定是单元组时的SELECT语句, 都可直接嵌入在主程序中使用,不必涉及到游标. (2)当SELECT语句查询结果是多个元组时,此时宿主语言程序无法使用, 一定要用游标机制把多个元组一次一个地传送给宿主语言处理.Oracle面试题库-PL/SQL1 PL/SQL代表A PROCEDURAL LANG

15、UAGE/SQLB PROGRAM LANGUAGE SQLC POWER LANGUAGE SQLD 都不对2 _引擎执行PL/SQL块A SQLB PL/SQLC ORACLE3 一个对象可以呈现多种形式的能力称为A 多态B 继承C 封装D 以上都不对4 PLSQL块是由哪几个部分组成A DECLARE BEGIN ENDB BEGIN ENDC EXCEPTION BEGIN ENDD DECLARE BEGIN EXCEPTION END5 看下面代码,正确的是A DECLAREDBMS_OUTPUT.PUT_LINE(定义部分);BEGINDBMS_OUTPUT.PUT_LINE(语

16、句部分);END;B BEGINNUM NUMBER:=100;DBMS_OUTPUT.PUT_LINE(NUM 的值为:|NUM);C DECLARENUM:=NUM+NUM/2;D BEGINDECLARE6 看下面语句正确的是A IF(N%M=0) THENDBMS_OUTPUT.PUT_LINE(这是一个偶数);ELSEIF(N%M=1) THENDBMS_OUTPUT.PUT_LINE(这是一个奇数);END IF;B DECLAREVAR NUMBER:=0;VAR:=&V;CASEWHEN VAR=1 THENDBMS_OUTPUT.PUT_LINE(A);WHEN VAR=2

17、THENDBMS_OUTPUT.PUT_LINE(B);ELSEDBMS_OUTPUT.PUT_LINE(O);END CASE;I NUMBER:FOR I IN 10.20 LOOPDBMS_OUTPUT.PUT_LINE(I);END LOOP;D LOOP7. 当在一个PLSQL块中通过查询得到一个值,但是没有任何值返回时,会产生异常吗?如果产生,是什么异常?A 不会有异常,只不过没有结果而已B 有异常,异常为No_data_foundC 有异常,异常为Value_erroD 编译都不通过8. 在PLSQL块中处理异常的语句是A EXCEPTIONIF EXCEPTION_NAME T

18、HENDBMS_OUTPUT.PUT_LINE();B EXCEPTIONWHEN EXCEPTION_NAME THENEND EXCEPTION ;C WHEN EXCEPTION_NAME THENNULL;EXCEPTIONEND ;9. 当用户在PLSQL块中,像抛出自定义异常或者是系统异常时,所使用的关键字是A THROWB RAISEC RAISE_APPLICATION_ERRORD EXCEPTION10. 在自定义异常中,用户可用的错误号范围在A 20000 29999B -20000 -20999C 165535D 没有限制11. 阅读代码DBMS_OUTPUT.PUT_LINE(外不快);MYEXCE EXCEPTION;

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1