SQL实践题:计算机系学生信息与课程关联查询
需积分: 18 22 浏览量
更新于2024-09-07
3
收藏 72KB DOC 举报
在SQL练习中,涉及到了数据库操作的多个核心概念和技能,主要围绕教育数据库Education中的三个关系:学生S、学习SC和课程C。以下是针对各个查询问题的详细解析:
1. **检索计算机系的全体学生的学号,姓名和性别**:
这个查询的目标是获取所有计算机科学(CS)系的学生信息。SQL语句如下:
```
SELECT Sno, Sname, Sex
FROM S
WHERE Sdept = 'CS';
```
这里利用了`WHERE`子句来筛选出Sdept字段值为'CS'的学生记录。
2. **检索学习课程号为C2的学生学号与姓名**:
要找到选修C2课程的学生,需要通过课程关系C间接链接学生和课程。首先找到C表中名为'DS'的课程号,然后关联SC表找出对应的学号。SQL语句如下:
```
SELECT Sno, Sname
FROM S
WHERE Sno IN
(SELECT Sno
FROM SC
WHERE Cno IN
(SELECT Cno
FROM C
WHERE Cname = 'DS')
);
```
3. **检索选修课程名为“DS”的学生学号与姓名**:
类似于上一个查询,先找到'DS'课程,然后关联学号。这里是两层嵌套的`IN`操作。
4. **检索选修课程号为C2或C4的学生学号**:
这个查询使用`OR`逻辑,直接在SC表中查找Cno为'C2'或'C4'的学生学号:
```
SELECT Sno
FROM SC
WHERE Cno = 'C2' OR Cno = 'C4';
```
5. **检索至少选修课程号为C2和C4的学生学号**:
这需要联合查询两个SC表(SCX和SCY),确保每个学生都选修了C2和C4:
```
SELECT Sno
FROM SCX, SCY
WHERE X.Sno = Y.Sno AND X.Cno = 'C2' AND Y.Cno = 'C4';
```
6. **检索不学C2课的学生姓名和年龄**:
查询不在课程C中出现的C2课程的学生信息,即不存在C表中Cno为'C2'的记录:
```
SELECT Sname, Age
FROM S
WHERE NOT EXISTS
(SELECT *
FROM C
WHERE Cno = 'C2'
);
```
7. **检索学习全部课程的学生姓名**:
该问题需要检查学生是否对所有课程都有对应的学习记录,即在C表中不存在学生未选修的课程。这可以通过外连接和否定条件实现,但由于此处的描述略有歧义,实际实现可能需要根据数据库设计和完整性约束来确定。
8. **查询所学课程包含学生S3所学课程的学生学号**:
这个问题可能是要求找出除了S3之外,还有哪些学生选修了S3所选的所有课程。如果S3的所有课程都是唯一的,可以使用`EXCEPT`操作符,但如果存在重复课程,可能需要更复杂的子查询或者联合查询。
以上SQL练习题目涵盖了SQL基础查询、多表联接、嵌套查询、逻辑运算以及复杂条件的筛选,对于学习者来说,这些题目既有助于巩固基础操作,也能提升对SQL高级特性的理解和应用能力。
2020-01-04 上传
2014-06-22 上传
2008-10-25 上传
2021-10-20 上传
2012-05-23 上传
2023-07-21 上传
2023-07-13 上传