(完整版)《数据库》第4章习题答案

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

4.2 对于教学数据库的三个基本表

S(SNO,SNAME,AGE,SEX,SDEPT)

SC(SNO,CNO,GRADE)

C(CNO,CNAME,CDEPT,TNAME)

试用SQL的查询语句表达下列查询:

①检索LIU老师所授课程的课程号和课程名。

②检索年龄大于23岁的男学生的学号和姓名。

③检索至少选修LIU老师所授课程中一门课程的女学生姓名。

④检索WANG同学不学的课程的课程号。

⑤检索至少选修两门课程的学生学号。

⑥检索全部学生都选修的课程的课程号与课程名。

⑦检索选修课程包含LIU老师所授(全部)课程的学生学号。

参考答案:

SELECT CNO,CNAME

FROM C

WHERE TNAME=‘LIU’;

SELECT SNO,SNAME

FROM S

WHERE AGE>23AND SEX=‘M’;

SELECT SNAME(联接查询方式)

FROM S,SC,C

WHERE S.SNO=SC.SNO AND O=O

AND SEX=’F’ AND TNAME=’LIU’;

或:SELECT SNAME (嵌套查询方式)

FROM S

WHERE SEX=‘F’

AND SNO IN(SELECT SNO

FROM SC

WHERE CNO IN (SELECT CNO

FROM C

WHERE TNAME=’LIU’));

或:SELECT SNAME (存在量词方式)

FROM S

WHERE SEX=‘F’

AND EXISTS(SELECT*

FROM SC

WHERE SC.SNO=S.SNO

AND EXISTS(SELECT *

FROM C

WHERE O=O

AND TNAME=’LIU’)); SELECT CNO

FROM C

WHERE NOT EXISTS

(SELECT *

FROM S,SC

WHERE S.SNO=SC.SNO AND O=O

AND SNAME=’WANG’);

或:SELECT CNO

FROM C

WHERE CNO NOT IN

(SELECT O

FROM S,SC

WHERE S.SNO=SC.SNO AND SNAME=’WANG’);或:SELECT CNO

FROM C

WHERE CNO NOT IN

(SELECT CNO

FROM SC

WHERE SNO IN

(SELECT SNO

FROM S

WHERE SNAME=’WANG’));

SELECT DISTINCT X..SNO

FROM SC AS X,SC AS Y

WHERE X.SNO=Y.SNO AND O<>O;

或:SELECT SNO

FROM SC

GROUP BY SNO HAVING COUNT(CNO)>=2; SELECT CNO,CNAME

FROM C

WHERE NOT EXISTS

(SELECT *

FROM S

WHERE NOT EXISTS

(SELECT *

FORM SC

WHERE SC.SNO=S.SNO AND O=O)); SELECT DISTINCT SNO

FROM SC AS X

WHERE NOT EXISTS

(SELECT *

FORM C

WHERE TNAME=’LIU’

AND NOT EXISTS

(SELECT *

FROM SC AS Y

WHERE Y.SNO=X.SNO AND O=O));

4.3 设有两个基本表R(A,B,C)和S(D,E,F),试用SQL查询语句表达下列关系代数表达式:

SELECT A FROM R;

SELECT * FROM R WHERE B=17;

SELECT * FROM R,S;

SELECT A,F FROM R,S WHERE C=D;

4.4 设有两个基本表R(A,B,C)和S(A,B,C),试用SQL查询语句表达下列关系代数表达式:

1.(SELECT * FROM R)

UNION

(SELECT * FROM S);

2.(SELECT * FROM R)

INTERSECT

(SELECT * FROM S);

3.(SELECT * FROM R)

EXCEPT

(SELECT * FROM S);

4.(SELECT A,B FROM R)

NATURAL INNER JOIN

(SELECT B,C FROM S);

或:SELECT R.A, R.B, S.C

FROM R,S

WHERE R.B=S.B

4.6 试用SQL查询语句表达下列对教学数据库中三个基本表S、SC、C的查询:

1、统计有学生选修的课程门数。

2、求选修C4课程的学生的平均年龄。

3、求LIU老师所授课程的每门课程的学生平均成绩。

4、统计每门课程的学生选修人数(超过10人的课程才统计)。要求输出课程号和选修人数,查询结果按人数降序排列,若人数相同,按课程号升序排列。

5、检索学号比WANG同学大,而年龄比他小的学生姓名。

6、检索姓名以WANG打头的所有学生的姓名和年龄。

7、在SC中检索成绩为空值的学生学号和课程号。

8、求年龄大于女同学平均年龄的男学生姓名和年龄。

9、求年龄大于所有女同学年龄的男学生姓名和年龄。

参考答案:

SELECT COUNT(DISTINCT CNO)

FROM SC;

SELECT AVG(AGE)

FROM S,SC

WHERE S.SNO=SC.SNO AND CNO=’C4’;

相关文档
最新文档