查询出所有没有选修“胡美丽”老师所讲课程的学生的学号myql实现
时间: 2024-05-30 07:13:31 浏览: 4
我可以为您提供MySQL查询语句,用于查询所有未选修“胡美丽”老师所讲授课程的学生学号:
SELECT DISTINCT s.id
FROM students s
WHERE NOT EXISTS (
SELECT 1
FROM courses c
JOIN teachers t ON c.teacher_id = t.id
WHERE c.student_id = s.id AND t.name = '胡美丽'
);
相关问题
MySQL查询所有没有选修课程的学生的学号、姓名
假设我们有以下两张表:
学生表 (students):
| 学号 | 姓名 |
| ---- | -----|
| 1 | 张三 |
| 2 | 李四 |
| 3 | 王五 |
| 4 | 赵六 |
选课表 (course_selections):
| 学号 | 课程编号 |
| ---- | -----|
| 1 | 1001 |
| 1 | 1002 |
| 2 | 1001 |
| 3 | 1003 |
则查询所有没有选修课程的学生的学号、姓名的SQL语句如下:
```
SELECT s.学号, s.姓名
FROM 学生表 s
LEFT JOIN 选课表 c ON s.学号 = c.学号
WHERE c.学号 IS NULL;
```
该语句使用了左连接(LEFT JOIN)将学生表和选课表连接起来,然后使用 WHERE 子句过滤出选修课程为空的记录,最后只查询学号和姓名两个字段。
mysql查询选修了所有课程的学生的学号
以下是查询选修了所有课程的学生的学号的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,该学生的学号会被查询出来。
相关推荐
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![doc](https://img-home.csdnimg.cn/images/20210720083327.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)