mysql查询选修了所有课程的学生的学号
时间: 2023-11-24 15:50:24 浏览: 1277
以下是查询选修了所有课程的学生的学号的MySQL语句:
```
SELECT `Sno`
FROM student
WHERE NOT EXISTS (
SELECT *
FROM course
WHERE NOT EXISTS (
SELECT *
FROM sc
WHERE sc.`Sno` = student.`Sno` AND sc.`Cno` = course.`Cno`
)
)
```
该语句使用了子查询和NOT EXISTS关键字,首先在student表中查询所有学生的学号,然后在course表中查询所有课程,最后在sc表中查询该学生是否选修了该课程。如果该学生没有选修该课程,则NOT EXISTS返回TRUE,表示该学生没有选修所有课程,该学生的学号不会被查询出来。如果该学生选修了所有课程,则NOT EXISTS返回FALSE,该学生的学号会被查询出来。
相关问题
mysql数据库 查询计算机系的学生的学号、姓名; 查询选修了数据库课程的学生学号姓名和成绩; 查询选修了学号为's02'的学生的全部选修课程的学生的学号姓名和系别。
以下是三个 MySQL 查询语句,用于实现您的要求:
1. 查询计算机系的学生的学号、姓名:
```
SELECT 学号, 姓名 FROM 学生 WHERE 系别 = '计算机系';
```
2. 查询选修了数据库课程的学生学号姓名和成绩:
```
SELECT 学生.学号, 学生.姓名, 成绩.分数
FROM 学生, 成绩, 课程
WHERE 学生.学号 = 成绩.学号 AND 成绩.课程编号 = 课程.课程编号 AND 课程.课程名称 = '数据库';
```
3. 查询选修了学号为's02'的学生的全部选修课程的学生的学号姓名和系别:
```
SELECT 学生.学号, 学生.姓名, 学生.系别
FROM 学生, 选课
WHERE 学生.学号 = 选课.学号 AND 选课.课程编号 IN (SELECT 选课.课程编号 FROM 选课 WHERE 选课.学号 = 's02');
```
这些查询语句可能需要根据您的具体数据表结构稍作修改。
mysql查询选修了三门以上课程的学生学号
以下是查询选修了三门以上课程的学生学号的MySQL语句:
```mysql
SELECT student_id FROM student_course GROUP BY student_id HAVING COUNT(*) >= 3;
```
该语句中,首先使用GROUP BY对学生ID进行分组,然后使用HAVING COUNT(*) >= 3筛选出选修了三门以上课程的学生ID。
阅读全文