(完整版)《数据库》第4章习题答案
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 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’;