在 Reports 表中查询至少选修课了程号为 C01 和 Co2 的学生学号和姓名。。 ←
时间: 2024-03-17 22:41:56 浏览: 108
您可以使用以下 SQL 查询语句来实现:
```
SELECT s.sno, s.sname
FROM student s
WHERE s.sno IN (
SELECT r.sno
FROM reports r
WHERE r.cno = 'C01' OR r.cno = 'C02'
GROUP BY r.sno
HAVING COUNT(DISTINCT r.cno) = 2
)
```
这个查询语句中,我们使用了子查询来找到选修了 C01 和 C02 两门课的学生编号,然后用这些学生的编号在学生表中查询对应的学生姓名。其中,`IN` 关键字用于判断学生编号是否在子查询的结果集中,`GROUP BY` 和 `HAVING` 语句用于筛选仅选修了 C01 和 C02 两门课的学生。
相关问题
在成绩表中查询至少选修课课程号为c01.c02的学生学号和姓名
好的,我理解了你的问题。根据你的要求,我可以给出以下 SQL 查询语句:
```sql
SELECT s.s_id, s.s_name
FROM student s
WHERE EXISTS (
SELECT *
FROM score sc
WHERE sc.s_id = s.s_id
AND sc.c_id IN ('c01', 'c02')
GROUP BY sc.s_id
HAVING COUNT(DISTINCT sc.c_id) >= 2
)
```
这个查询语句中,我们首先在 `score` 表中找到所有选修了课程号为 `c01` 或 `c02` 的成绩记录,然后按学生 ID 分组,只保留选修了这两门课的学生,最后再在 `student` 表中找到这些学生的学号和姓名。
(3)在Reports表中查询至少选修课了程号为C01和C02的学生学号和姓名。 (4)查询既没有选修课程号C01,也没有选修课程号C02的学生的学号和姓名。 (5) 查询每个同学基本信息及其选修课程的情况。 (6)查询每个学生及其选修课程的情况(若某一个学生没有选课,只输出学生的基本情况信息,其选课信息为空值)。 (7)查询选修了课程名为“GIS开发”的学生学号和姓名。 (8) 查询没有选修C02课程的学生学号和姓名。
好的,我将依次回答你的问题:
(3) 查询选修了程号为C01和C02的学生学号和姓名:
```
SELECT s.sno, s.sname
FROM Student s
WHERE s.sno IN (
SELECT r.sno
FROM Reports r
WHERE r.cno = 'C01'
) AND s.sno IN (
SELECT r.sno
FROM Reports r
WHERE r.cno = 'C02'
);
```
(4) 查询既没有选修课程号C01,也没有选修课程号C02的学生的学号和姓名:
```
SELECT s.sno, s.sname
FROM Student s
WHERE s.sno NOT IN (
SELECT r.sno
FROM Reports r
WHERE r.cno = 'C01'
) AND s.sno NOT IN (
SELECT r.sno
FROM Reports r
WHERE r.cno = 'C02'
);
```
(5) 查询每个同学基本信息及其选修课程的情况:
```
SELECT s.sno, s.sname, s.ssex, s.sage, r.cno, c.cname, c.ccredit, r.grade
FROM Student s
LEFT JOIN Reports r ON s.sno = r.sno
LEFT JOIN Course c ON r.cno = c.cno;
```
(6) 查询每个学生及其选修课程的情况(若某一个学生没有选课,只输出学生的基本情况信息,其选课信息为空值):
```
SELECT s.sno, s.sname, s.ssex, s.sage, r.cno, c.cname, c.ccredit, r.grade
FROM Student s
LEFT JOIN Reports r ON s.sno = r.sno
LEFT JOIN Course c ON r.cno = c.cno;
```
(7) 查询选修了课程名为“GIS开发”的学生学号和姓名:
```
SELECT s.sno, s.sname
FROM Student s
INNER JOIN Reports r ON s.sno = r.sno
INNER JOIN Course c ON r.cno = c.cno
WHERE c.cname = 'GIS开发';
```
(8) 查询没有选修C02课程的学生学号和姓名:
```
SELECT s.sno, s.sname
FROM Student s
WHERE s.sno NOT IN (
SELECT r.sno
FROM Reports r
WHERE r.cno = 'C02'
);
```
阅读全文