学生(学号,年龄,性别,系名) 课程(课号,课名,学分,学时) 选课(学号,课号,成绩) 根据上面基本表的信息完成下列查询。 1 查询选修了数据库原理的学生的人数和平均成绩。 2 查询选修3门课 以上的学生姓名。 3列出人数超过1000人的系名。 4 查询所有课程都及格的学生姓名。用sql语句完成查询curpos-1232-396-438
时间: 2023-09-18 10:06:36 浏览: 162
c语言课程设计
1. 查询选修了数据库原理的学生的人数和平均成绩。
```
SELECT COUNT(DISTINCT 选课.学号) AS 选修人数, AVG(选课.成绩) AS 平均成绩
FROM 选课
JOIN 学生 ON 学生.学号 = 选课.学号
JOIN 课程 ON 课程.课号 = 选课.课号
WHERE 课程.课名 = '数据库原理';
```
2. 查询选修3门课以上的学生姓名。
```
SELECT 学生.姓名
FROM 学生
JOIN (
SELECT 学号, COUNT(*) AS 选修课程数
FROM 选课
GROUP BY 学号
HAVING COUNT(*) >= 3
) AS 选修课程数表 ON 选修课程数表.学号 = 学生.学号;
```
3. 列出人数超过1000人的系名。
```
SELECT 系名
FROM 学生
GROUP BY 系名
HAVING COUNT(DISTINCT 学号) > 1000;
```
4. 查询所有课程都及格的学生姓名。
```
SELECT 学生.姓名
FROM 学生
WHERE NOT EXISTS (
SELECT *
FROM 课程
WHERE NOT EXISTS (
SELECT *
FROM 选课
WHERE 选课.学号 = 学生.学号 AND 选课.课号 = 课程.课号 AND 选课.成绩 >= 60
)
);
```
阅读全文